Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
檀越@新空间
python-algorithm
提交
ad7247dd
P
python-algorithm
项目概览
檀越@新空间
/
python-algorithm
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
python-algorithm
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
ad7247dd
编写于
7月 10, 2023
作者:
檀越@新空间
🐭
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix:最接近的三数之和
上级
d00af2af
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
81 addition
and
0 deletion
+81
-0
01-数组/day04/problem_solving_07.py
01-数组/day04/problem_solving_07.py
+36
-0
02-链表/problem_solving_06.py
02-链表/problem_solving_06.py
+45
-0
未找到文件。
01-数组/day04/problem_solving_07.py
0 → 100644
浏览文件 @
ad7247dd
"""
最接近的三数之和
"""
import
heapq
from
typing
import
List
class
Solution
:
def
threeSumClosest
(
self
,
nums
:
List
[
int
],
target
:
int
)
->
int
:
"""
思路:最关键的是找出最接近的数
:param nums:
:param target:
:return:
"""
nums
.
sort
()
ans
=
nums
[
0
]
+
nums
[
1
]
+
nums
[
2
]
for
i
in
range
(
len
(
nums
)):
left
=
i
+
1
right
=
len
(
nums
)
-
1
while
left
<
right
:
total
=
nums
[
i
]
+
nums
[
left
]
+
nums
[
right
]
if
abs
(
target
-
total
)
<
abs
(
target
-
ans
):
ans
=
total
if
total
>
target
:
right
-=
1
elif
total
<
target
:
left
+=
1
else
:
return
total
return
ans
if
__name__
==
'__main__'
:
result
=
Solution
().
threeSumClosest
([
-
1
,
2
,
1
,
-
4
],
1
)
print
(
result
)
02-链表/problem_solving_06.py
0 → 100644
浏览文件 @
ad7247dd
"""
相交链表
"""
from
typing
import
List
,
Optional
class
ListNode
:
def
__init__
(
self
,
val
=
0
,
next
=
None
):
self
.
val
=
val
self
.
next
=
next
class
Solution
:
def
getIntersectionNode
(
self
,
headA
:
ListNode
,
headB
:
ListNode
)
->
Optional
[
ListNode
]:
"""
思路:如果存在交点,则肯定在两个链表分别遍历对方时相交
:param headA:
:param headB:
:return:
"""
if
not
headA
or
not
headB
:
return
None
nodeA
,
nodeB
=
headA
,
headB
while
nodeA
!=
nodeB
:
nodeA
=
nodeA
.
next
if
nodeA
else
headB
nodeB
=
nodeB
.
next
if
nodeB
else
headA
return
nodeA
if
__name__
==
'__main__'
:
l1
=
ListNode
(
4
)
l1
.
next
=
ListNode
(
1
)
l1
.
next
.
next
=
ListNode
(
8
)
l1
.
next
.
next
.
next
=
ListNode
(
4
)
l1
.
next
.
next
.
next
.
next
=
ListNode
(
5
)
# l1.next.next.next.next.next = ListNode(9)
# l1.next.next.next.next.next.next = ListNode(9)
l2
=
ListNode
(
5
)
l2
.
next
=
ListNode
(
6
)
l2
.
next
.
next
=
ListNode
(
1
)
l2
.
next
.
next
.
next
=
ListNode
(
8
)
l2
.
next
.
next
.
next
.
next
=
ListNode
(
4
)
l2
.
next
.
next
.
next
.
next
.
next
=
ListNode
(
5
)
result
=
Solution
().
getIntersectionNode
(
l1
,
l2
)
print
(
result
)
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录