704. 二分查找
代码
左闭右闭 – [left, right]
class Solution:
def search(self, nums: List[int], target: int) -> int:
l, r = 0, len(nums)-1
while l <= r:
mid = l + (r - l) // 2 #C++ 里面防止溢出,python中没这个考虑
if nums[mid] < target:
l = mid + 1
elif nums[mid] > target:
r = mid - 1
else:
return mid
return -1
左闭右开 – [left, right)
因为取值取不到nums[r],所以我们有l < r和r = mid的改动。
class Solution:
def search(self, nums: List[int], target: int) -> int:
l, r = 0, len(nums)
while l < r:
mid = l + (r - l) // 2
if nums[mid] < target:
l = mid + 1
elif nums[mid] > target:
r = mid
else:
return mid
return -1
27. 移除元素
代码
双指针
class Solution:
def removeElement(self, nums: List[int], val: int) -> int:
l, r = 0, len(nums) - 1
while l <= r:
if nums[l] == val:
nums[l] = nums[r]
r -= 1
else:
l += 1
return l
二分题练习
875. 爱吃香蕉的珂珂
代码
class Solution:
def minEatingSpeed(self, piles: List[int], h: int) -> int:
l, r = 1, max(piles)
res = r
while l <= r:
speed = l + (r - l) // 2
total_time = 0
for p in piles:
total_time += math.ceil(float(p) / speed)
if total_time <= h:
res = speed
r = speed - 1
else:
l = speed + 1
return res
Python二分查找与移除元素示例及应用
文章介绍了Python实现的二分查找算法,包括左闭右闭和左闭右开两种情况,以及使用双指针的移除元素方法。还展示了如何用二分法解决爱吃香蕉的珂珂问题,优化求解速度。
1123

被折叠的 条评论
为什么被折叠?



