力扣hot100_二分查找(2)_python版本

一、二分查找

  1. 如果查找不到,返回的是该插入位置
  2. 如果有多个值和target一样,返回的是第一个
python 复制代码
def binary_search(nums, target):
	left, right = -1, len(nums)
	while left+1<right:
        # 循环不变量
        # nums[left] < target
        # nums[right] >= target
		mid = (left+right)//2
		if nums[mid] < target:   # 和循环不变量对齐
			left = mid
		else:
			right = mid
	return right

二、红蓝染色法

  • 基本概念
    红蓝染色法是一种借助二分查找高效解决:需要找到满足特定条件的所有元素中的第一个或最后一个位置的情况
    红色区域:小于当前值的
    蓝色区域:大于等于当前值的

应用场景:

  • 找到 ≥ x ≥x ≥x的第一个元素
  • 找到 > x >x >x的第一个元素
  • 找到 ≤ x ≤x ≤x的最后一个元素
  • 找到 < x <x <x的最后一个元素

换句话说:二分查找的目标是找到红蓝边界,即第一个满足条件的元素。

三、162. 寻找峰值

  • 思路:红蓝染色法
    每次用nums[mid] 和 nums[mid+1] 比较,如果nums[mid] > nums[mid+1],那么右边全是红色(小于target),否则,左边全是红色
  • 代码:
python 复制代码
class Solution:
    def findPeakElement(self, nums: List[int]) -> int:
    ''''
    因为最右边元素一定要么是峰顶,要么是峰顶左边元素,所以不用检测(否则下面的代码报错,当峰顶就是最右的时候)
    为什么要检测-1,因为返回的right,本身right就是指向>=target的。
	'''
        left, right = -1, len(nums)-1 
        while left+1<right:
            mid = (left+right)//2
            if nums[mid] > nums[mid+1]:
                right = mid
            else:
                left=mid
        return right

三、153. 寻找旋转排序数组中的最小值

  • 思路:
    假设数组最后一个元素是最小值或者最小值的左值,那么直接做二分查找,把最后一个元素当作最小值就行。
    假设数组最后一个元素不是最小值或者其左值,那么根据红蓝染色法,二分查找可以找到第一个满足条件的元素。
  • 代码:
python 复制代码
class Solution:
    def findMin(self, nums: List[int]) -> int:
        left, right = -1, len(nums)-1
        while left+1<right:
            mid = (left+right)//2
            if nums[mid] < nums[-1]:
                right = mid
            else:
                left = mid
        return nums[right]

一、33. 搜索旋转排序数组

  • 思路:
相关推荐
菜包eo1 小时前
二维码驱动的独立站视频集成方案
网络·python·音视频
Yo_Becky1 小时前
【PyTorch】PyTorch预训练模型缓存位置迁移,也可拓展应用于其他文件的迁移
人工智能·pytorch·经验分享·笔记·python·程序人生·其他
yzx9910131 小时前
关于网络协议
网络·人工智能·python·网络协议
fangeqin1 小时前
ubuntu源码安装python3.13遇到Could not build the ssl module!解决方法
linux·python·ubuntu·openssl
martian6651 小时前
支持向量机(SVM)深度解析:从数学根基到工程实践
算法·机器学习·支持向量机
孟大本事要学习2 小时前
算法19天|回溯算法:理论基础、组合、组合总和Ⅲ、电话号码的字母组合
算法
Jay Kay2 小时前
TensorFlow源码深度阅读指南
人工智能·python·tensorflow
FF-Studio2 小时前
【硬核数学 · LLM篇】3.1 Transformer之心:自注意力机制的线性代数解构《从零构建机器学习、深度学习到LLM的数学认知》
人工智能·pytorch·深度学习·线性代数·机器学习·数学建模·transformer
会的全对٩(ˊᗜˋ*)و2 小时前
【数据挖掘】数据挖掘综合案例—银行精准营销
人工智能·经验分享·python·数据挖掘
云渚钓月梦未杳2 小时前
深度学习03 人工神经网络ANN
人工智能·深度学习