【LeetCode刷题】专题三:二分查找模板

【LeetCode刷题】Day 11

  • 专题三:二分查找模板:
    • [1. 朴素二分模板:](#1. 朴素二分模板:)
    • [2. 区间左值模板:](#2. 区间左值模板:)
    • [3. 区间右值模板:](#3. 区间右值模板:)
  • [题目1:704. 二分查找](#题目1:704. 二分查找)
  • [题目2:34. 在排序数组中查找元素的第一个和最后一个位置](#题目2:34. 在排序数组中查找元素的第一个和最后一个位置)
    • 思路分析:
    • [思路1:区间左右值二分查找 O(logN)](#思路1:区间左右值二分查找 O(logN))

专题三:二分查找模板:

:
1. 判断条件:while(......)left<=right 还是left<right。这是第一个容易死循环的点。

:
2. 求中点的方式:mid = left + (right-left)/2 还是 mid = left + (right-left+1)/2这个点很关键。如果和下面mid的迭代不相符,这便是第二个死循环的点。

:
3. left和right的迭代:是left = mid还是left = mid+1、是right = mid还是right = mid -1这都是需要清除的问题。

1. 朴素二分模板:

cpp 复制代码
while (left <= right)
{
	int mid = left + (right - left) / 2;
	if (......)
		right = mid - 1;
	else if (......)
		left = mid + 1;
	else
		return mid;
}

2. 区间左值模板:

特点: 左值:左动,下有+1上不加;

cpp 复制代码
while(left<right)
{
	int mid=left+(right-left)/2;
	if(...) left=mid+1;
	else right=mid;
}

3. 区间右值模板:

特点: 右值:右动,下有-1+1

cpp 复制代码
while(left<right)
{
	int mid=left+(right-left+1)/2;
	if(...) right=mid-1;
	else left=mid;
}

题目1:704. 二分查找

思路分析:

思路1:朴素二分查找O(logN)

代码实现:

cpp 复制代码
class Solution {
public:
    int search(vector<int>& nums, int target) {
        int left = 0, right = nums.size() - 1;
        while (left <= right) {
            int mid = left + (right - left) / 2;
            if (nums[mid] > target)
                right = mid - 1;
            else if (nums[mid] < target)
                left = mid + 1;
            else
                return mid;
        }
        return -1;
    }
};

LeetCode链接:704. 二分查找


题目2:34. 在排序数组中查找元素的第一个和最后一个位置

思路分析:

:
主要三个点:判断条件、mid取值、left和right迭代

思路1:区间左右值二分查找 O(logN)

代码实现

cpp 复制代码
class Solution {
public:
    vector<int> searchRange(vector<int>& nums, int target) {
        int left=0,right=nums.size()-1;
        int begin=-1,end=-1;    
        if(nums.empty()) return {-1,-1}; 
        //1.区间左端点查找: 二分区间:[小于目标值][大于等于目标值] left维护前者,right维护后置,目标值在right区间左端取到。
        while(left<right)		//判断:为什么不能等于,因为最终结果是left=right处取到,=就死循环
        {
            int mid=left+(right-left)/2;	//当还剩最后left和right相邻时,指向左端点,结合迭代,左端点可以跳出来,右端点不能。
            if(nums[mid]>=target) right=mid;	//right不跳出区间,因为可能目标值就是right处
            else left=mid+1;					//left需要移动,因为目标值一定不在它的区间
        }
        if(target==nums[left])  begin=left;
        //2.区间左端点查找:  
        right=nums.size()-1;	//注意更新left和right,优化:右端点一定在左端点后,所以left可以不更新,就处于左端点处
        while(left<right)
        {
            int mid=left+(right-left+1)/2;	
            if(nums[mid]>target) right=mid-1;
            else left=mid;
        }
        if(target==nums[left])    end=left;
        
        return {begin,end};
    }
};

LeetCode刷题:34.在排序数组中查找元素的第一个和最后一个位置


进入二分,我更强大!!! ~天天开心🎈

相关推荐
兩尛6 小时前
HJ98 喜欢切数组的红(dp
算法
adam_life6 小时前
【P4551 最长异或路径】
算法·bfs·01字典树
CoovallyAIHub6 小时前
2025年值得关注的5款数据标注工具
深度学习·算法·计算机视觉
FuckPatience6 小时前
C# 补码
开发语言·算法·c#
稚辉君.MCA_P8_Java6 小时前
Gemini永久会员 VB返回最长有效子串长度
数据结构·后端·算法
小年糕是糕手6 小时前
【C++】类和对象(五) -- 类型转换、static成员
开发语言·c++·程序人生·考研·算法·visual studio·改行学it
Xの哲學6 小时前
Linux内核数据结构:设计哲学与实现机制
linux·服务器·算法·架构·边缘计算
秋深枫叶红7 小时前
嵌入式第二十七篇——数据结构——栈
c语言·数据结构·学习·算法
灵犀坠7 小时前
前端面试&项目实战核心知识点总结(Vue3+Pinia+UniApp+Axios)
前端·javascript·css·面试·职场和发展·uni-app·html
稚辉君.MCA_P8_Java7 小时前
Gemini永久会员 Java 返回最长有效子串长度
java·数据结构·后端·算法