Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
檀越@新空间
python-algorithm
提交
303f5c92
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看板
提交
303f5c92
编写于
7月 19, 2023
作者:
檀越@新空间
🐭
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix:二分查找
上级
82a6d75d
变更
9
隐藏空白更改
内联
并排
Showing
9 changed file
with
275 addition
and
0 deletion
+275
-0
999-算法思想/01-二分查找/problem_solving_01.py
999-算法思想/01-二分查找/problem_solving_01.py
+29
-0
999-算法思想/01-二分查找/problem_solving_02.py
999-算法思想/01-二分查找/problem_solving_02.py
+30
-0
999-算法思想/01-二分查找/problem_solving_03.py
999-算法思想/01-二分查找/problem_solving_03.py
+28
-0
999-算法思想/01-二分查找/problem_solving_04.py
999-算法思想/01-二分查找/problem_solving_04.py
+30
-0
999-算法思想/01-二分查找/problem_solving_05.py
999-算法思想/01-二分查找/problem_solving_05.py
+34
-0
999-算法思想/01-二分查找/problem_solving_06.py
999-算法思想/01-二分查找/problem_solving_06.py
+34
-0
999-算法思想/01-二分查找/problem_solving_07.py
999-算法思想/01-二分查找/problem_solving_07.py
+30
-0
999-算法思想/01-二分查找/problem_solving_08.py
999-算法思想/01-二分查找/problem_solving_08.py
+30
-0
999-算法思想/01-二分查找/problem_solving_09.py
999-算法思想/01-二分查找/problem_solving_09.py
+30
-0
未找到文件。
999-算法思想/01-二分查找/problem_solving_01.py
0 → 100644
浏览文件 @
303f5c92
"""
二分查找基础版
"""
from
typing
import
List
class
Solution
:
def
distributeCoins
(
self
,
nums
:
List
[
int
],
target
:
int
)
->
int
:
"""
二分查找基础版
:param nums:
:param target:
:return:
"""
left
,
right
=
0
,
len
(
nums
)
-
1
while
left
<=
right
:
mid
=
(
left
+
right
)
>>
1
if
nums
[
mid
]
>
target
:
right
=
mid
-
1
elif
nums
[
mid
]
<
target
:
left
=
mid
+
1
else
:
return
mid
return
-
1
if
__name__
==
'__main__'
:
result
=
Solution
().
distributeCoins
([
2
,
7
,
11
,
15
],
0
)
print
(
result
)
999-算法思想/01-二分查找/problem_solving_02.py
0 → 100644
浏览文件 @
303f5c92
"""
二分查找改变版
"""
from
typing
import
List
class
Solution
:
def
distributeCoins
(
self
,
nums
:
List
[
int
],
target
:
int
)
->
int
:
"""
二分查找改变版,如果增大了右边界,那最后的结果肯定不能取到right
:param nums:
:param target:
:return:
"""
left
,
right
=
0
,
len
(
nums
)
while
left
<
right
:
mid
=
(
left
+
right
)
>>
1
if
nums
[
mid
]
>
target
:
right
=
mid
elif
nums
[
mid
]
<
target
:
left
=
mid
+
1
else
:
return
mid
return
-
1
if
__name__
==
'__main__'
:
result
=
Solution
().
distributeCoins
([
2
,
7
,
11
,
15
],
11
)
print
(
result
)
999-算法思想/01-二分查找/problem_solving_03.py
0 → 100644
浏览文件 @
303f5c92
"""
二分查找平衡版
"""
from
typing
import
List
class
Solution
:
def
distributeCoins
(
self
,
nums
:
List
[
int
],
target
:
int
)
->
int
:
"""
二分查找平衡版
:param nums:
:param target:
:return:
"""
left
,
right
=
0
,
len
(
nums
)
while
1
<
right
-
left
:
mid
=
(
left
+
right
)
>>
1
if
nums
[
mid
]
>
target
:
right
=
mid
else
:
left
=
mid
return
left
if
target
==
nums
[
left
]
else
-
1
if
__name__
==
'__main__'
:
result
=
Solution
().
distributeCoins
([
2
,
7
,
11
,
15
],
6
)
print
(
result
)
999-算法思想/01-二分查找/problem_solving_04.py
0 → 100644
浏览文件 @
303f5c92
"""
二分查找java版
"""
from
typing
import
List
class
Solution
:
def
distributeCoins
(
self
,
nums
:
List
[
int
],
target
:
int
)
->
int
:
"""
二分查找java版,返回插入位置加1取反,加1的目的是区别0的位置
:param nums:
:param target:
:return:
"""
left
,
right
=
0
,
len
(
nums
)
-
1
while
left
<=
right
:
mid
=
(
left
+
right
)
>>
1
if
nums
[
mid
]
>
target
:
right
=
mid
-
1
elif
nums
[
mid
]
<
target
:
left
=
mid
+
1
else
:
return
mid
return
-
left
-
1
if
__name__
==
'__main__'
:
result
=
Solution
().
distributeCoins
([
2
,
7
,
11
,
15
],
1
)
print
(
result
)
999-算法思想/01-二分查找/problem_solving_05.py
0 → 100644
浏览文件 @
303f5c92
"""
二分查找Leftmost
"""
from
typing
import
List
class
Solution
:
def
distributeCoins
(
self
,
nums
:
List
[
int
],
target
:
int
)
->
int
:
"""
二分查找Leftmost,最左侧的重复元素
:param nums:
:param target:
:return:
"""
left
,
right
=
0
,
len
(
nums
)
-
1
candidate
=
-
1
while
left
<=
right
:
mid
=
(
left
+
right
)
>>
1
if
nums
[
mid
]
>
target
:
right
=
mid
-
1
elif
nums
[
mid
]
<
target
:
left
=
mid
+
1
else
:
# 找到后把值给候选人,右指针继续递减
candidate
=
mid
right
=
mid
-
1
return
candidate
if
__name__
==
'__main__'
:
result
=
Solution
().
distributeCoins
([
1
,
2
,
4
,
4
,
5
,
6
,
7
],
4
)
# result = Solution().distributeCoins([1, 2, 4, 4, 4, 5, 6, 7], 4)
print
(
result
)
999-算法思想/01-二分查找/problem_solving_06.py
0 → 100644
浏览文件 @
303f5c92
"""
二分查找Rightmost
"""
from
typing
import
List
class
Solution
:
def
distributeCoins
(
self
,
nums
:
List
[
int
],
target
:
int
)
->
int
:
"""
二分查找Rightmost,最右侧的重复元素
:param nums:
:param target:
:return:
"""
left
,
right
=
0
,
len
(
nums
)
-
1
candidate
=
-
1
while
left
<=
right
:
mid
=
(
left
+
right
)
>>
1
if
nums
[
mid
]
>
target
:
right
=
mid
-
1
elif
nums
[
mid
]
<
target
:
left
=
mid
+
1
else
:
# 找到后把值给候选人,右指针继续递减
candidate
=
mid
left
=
mid
+
1
return
candidate
if
__name__
==
'__main__'
:
# result = Solution().distributeCoins([1, 2, 4, 4, 5, 6, 7], 4)
result
=
Solution
().
distributeCoins
([
1
,
2
,
4
,
4
,
4
,
5
,
6
,
7
],
4
)
print
(
result
)
999-算法思想/01-二分查找/problem_solving_07.py
0 → 100644
浏览文件 @
303f5c92
"""
二分查找Leftmost
"""
from
typing
import
List
class
Solution
:
def
distributeCoins
(
self
,
nums
:
List
[
int
],
target
:
int
)
->
int
:
"""
二分查找Leftmost,小于等于左侧的的位置
:param nums:
:param target:
:return:
"""
left
,
right
=
0
,
len
(
nums
)
-
1
while
left
<=
right
:
mid
=
(
left
+
right
)
>>
1
if
nums
[
mid
]
>=
target
:
# 相等了不想返回,继续压缩右指针
right
=
mid
-
1
else
:
left
=
mid
+
1
return
left
if
__name__
==
'__main__'
:
# result = Solution().distributeCoins([1, 2, 4, 4, 5, 6, 7], 4)
result
=
Solution
().
distributeCoins
([
1
,
2
,
4
,
4
,
4
,
5
,
6
,
7
],
3
)
print
(
result
)
999-算法思想/01-二分查找/problem_solving_08.py
0 → 100644
浏览文件 @
303f5c92
"""
二分查找Rightmost
"""
from
typing
import
List
class
Solution
:
def
distributeCoins
(
self
,
nums
:
List
[
int
],
target
:
int
)
->
int
:
"""
二分查找Rightmost,大于最右侧的重复元素
:param nums:
:param target:
:return:
"""
left
,
right
=
0
,
len
(
nums
)
-
1
while
left
<=
right
:
mid
=
(
left
+
right
)
>>
1
if
nums
[
mid
]
>
target
:
right
=
mid
-
1
else
:
# 最后等于最后一个目标值的时候,又加了一次,所以在结果的时候需要减1
left
=
mid
+
1
return
left
-
1
if
__name__
==
'__main__'
:
# result = Solution().distributeCoins([1, 2, 4, 4, 5, 6, 7], 4)
result
=
Solution
().
distributeCoins
([
1
,
2
,
4
,
4
,
4
,
6
,
7
],
5
)
print
(
result
)
999-算法思想/01-二分查找/problem_solving_09.py
0 → 100644
浏览文件 @
303f5c92
"""
二分查找Rightmost,插入元素在最右边
"""
from
typing
import
List
class
Solution
:
def
distributeCoins
(
self
,
nums
:
List
[
int
],
target
:
int
)
->
int
:
"""
二分查找Rightmost,插入元素在最右边,返回的是插入的index,如果是排名需要再加1
:param nums:
:param target:
:return:
"""
left
,
right
=
0
,
len
(
nums
)
-
1
while
left
<=
right
:
mid
=
(
left
+
right
)
>>
1
if
nums
[
mid
]
>
target
:
right
=
mid
-
1
else
:
# 最后等于最后一个目标值的时候,又加了一次,所以在结果的时候需要减1
left
=
mid
+
1
return
left
if
__name__
==
'__main__'
:
# result = Solution().distributeCoins([1, 2, 4, 4, 5, 6, 7], 4)
result
=
Solution
().
distributeCoins
([
1
,
2
,
4
,
4
,
4
,
6
,
7
],
5
)
print
(
result
)
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录