Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
檀越@新空间
python-algorithm
提交
705a82cf
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看板
提交
705a82cf
编写于
7月 05, 2023
作者:
檀越@新空间
🐭
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix:三数之和
上级
bd73b753
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
101 addition
and
0 deletion
+101
-0
01-数组/day04/problem_solving_01.py
01-数组/day04/problem_solving_01.py
+29
-0
01-数组/day04/problem_solving_02_01.py
01-数组/day04/problem_solving_02_01.py
+22
-0
01-数组/day04/problem_solving_02_02.py
01-数组/day04/problem_solving_02_02.py
+14
-0
01-数组/day04/problem_solving_03.py
01-数组/day04/problem_solving_03.py
+36
-0
未找到文件。
01-数组/day04/problem_solving_01.py
0 → 100644
浏览文件 @
705a82cf
"""
盛最多水的容器
"""
from
typing
import
List
class
Solution
:
def
maxArea
(
self
,
height
:
List
[
int
])
->
int
:
"""
双指针
:param height:
:return:
"""
max_area
=
0
left
=
0
right
=
len
(
height
)
-
1
while
left
<
right
:
area
=
(
right
-
left
)
*
min
(
height
[
left
],
height
[
right
])
max_area
=
max
(
max_area
,
area
)
if
height
[
left
]
<
height
[
right
]:
left
+=
1
else
:
right
-=
1
return
max_area
if
__name__
==
'__main__'
:
result
=
Solution
().
maxArea
([
1
,
8
,
6
,
2
,
5
,
4
,
8
,
3
,
7
])
print
(
result
)
01-数组/day04/problem_solving_02_01.py
0 → 100644
浏览文件 @
705a82cf
"""
K 件物品的最大和
"""
from
typing
import
List
class
Solution
:
def
kItemsWithMaximumSum
(
self
,
numOnes
:
int
,
numZeros
:
int
,
numNegOnes
:
int
,
k
:
int
)
->
int
:
if
k
<=
numOnes
:
return
k
elif
numOnes
<
k
<=
(
numOnes
+
numZeros
):
return
numOnes
elif
(
numOnes
+
numZeros
)
<
k
<=
(
numOnes
+
numZeros
+
numNegOnes
):
return
numOnes
-
(
k
-
numOnes
-
numZeros
)
else
:
return
numOnes
-
numNegOnes
return
result
if
__name__
==
'__main__'
:
result
=
Solution
().
kItemsWithMaximumSum
(
3
,
2
,
0
,
2
)
print
(
result
)
01-数组/day04/problem_solving_02_02.py
0 → 100644
浏览文件 @
705a82cf
"""
K 件物品的最大和
"""
from
typing
import
List
class
Solution
:
def
kItemsWithMaximumSum
(
self
,
numOnes
:
int
,
numZeros
:
int
,
numNegOnes
:
int
,
k
:
int
)
->
int
:
return
numOnes
-
(
k
-
numOnes
+
numZeros
)
if
k
>
(
numOnes
+
numZeros
)
else
min
(
numOnes
,
k
)
if
__name__
==
'__main__'
:
result
=
Solution
().
kItemsWithMaximumSum
(
3
,
2
,
0
,
2
)
print
(
result
)
01-数组/day04/problem_solving_03.py
0 → 100644
浏览文件 @
705a82cf
"""
三数之和
"""
from
typing
import
List
class
Solution
:
def
threeSum
(
self
,
nums
:
List
[
int
])
->
List
[
List
[
int
]]:
nums
.
sort
()
res
=
[]
for
i
in
range
(
len
(
nums
)
-
2
):
if
nums
[
i
]
>
0
:
break
if
i
>
0
and
nums
[
i
]
==
nums
[
i
-
1
]:
continue
left
,
right
=
i
+
1
,
len
(
nums
)
-
1
while
left
<
right
:
total
=
nums
[
i
]
+
nums
[
left
]
+
nums
[
right
]
if
total
<
0
:
left
+=
1
elif
total
>
0
:
right
-=
1
else
:
res
.
append
([
nums
[
i
],
nums
[
left
],
nums
[
right
]])
while
left
<
right
and
nums
[
left
]
==
nums
[
left
+
1
]:
left
+=
1
while
left
<
right
and
nums
[
right
]
==
nums
[
right
-
1
]:
right
-=
1
left
+=
1
right
-=
1
return
res
if
__name__
==
'__main__'
:
result
=
Solution
().
threeSum
([
-
1
,
0
,
1
,
2
,
-
1
,
-
4
])
print
(
result
)
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录