寒假打卡:2026-2-23

二分查找算法:
特点:细节+容易写出死循环

算法原理:适用于数组有序的情况(大部分)

模板:

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

例题:

给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果 target 存在返回下标,否则返回 -1

你必须编写一个具有 O(log n) 时间复杂度的算法。

示例 1:

复制代码
输入: nums = [-1,0,3,5,9,12], target = 9
输出: 4
解释: 9 出现在 nums 中并且下标为 4

示例 2:

复制代码
输入: nums = [-1,0,3,5,9,12], target = 2
输出: -1
解释: 2 不存在 nums 中因此返回 -1
java 复制代码
class Solution {
    public int search(int[] nums, int target) {
        int left=0,right=nums.length-1;
        while(left<=right){
            int mid=left+(right-left)/2;
            if(nums[mid]<target){
                left=mid+1;
            }else if(nums[mid]>target){
                right=mid-1;
            }else{
                return mid;
            }
        }
        return -1;
    }
}

2.查找区间的左端点

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

3.查找区间的右端点

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

例题:

给你一个按照非递减顺序排列的整数数组 nums,和一个目标值 target。请你找出给定目标值在数组中的开始位置和结束位置。

如果数组中不存在目标值 target,返回 [-1, -1]

你必须设计并实现时间复杂度为 O(log n) 的算法解决此问题。

示例 1:

复制代码
输入:nums = [5,7,7,8,8,10], target = 8
输出:[3,4]

示例 2:

复制代码
输入:nums = [5,7,7,8,8,10], target = 6
输出:[-1,-1]

示例 3:

复制代码
输入:nums = [], target = 0
输出:[-1,-1]
java 复制代码
class Solution {
    public int[] searchRange(int[] nums, int target) {
        int[] ret=new int[2];
        ret[0]=ret[1]=-1;
        //处理边界情况
        if(nums.length==0) return ret;

        //二分左端点
        int left=0,right=nums.length-1;
        while(left<right){
            int mid=left+(right-left)/2;
            if(nums[mid]<target) left=mid+1;
            else right=mid;
        }
        //判断是否有结果
        if(nums[left]!=target) return ret;
        else ret[0]=right;

        //二分右端点
        left=0;right=nums.length-1;
        while(left<right){
            int mid=left+(right-left+1)/2;
            if(nums[mid]<=target) left=mid;
            else right=mid-1;
        }
         ret[1]=left;
         return ret;
    }
}
相关推荐
香蕉鼠片9 分钟前
数据结构八股(一)
数据结构·算法
起个破名想半天了17 分钟前
算法与数据结构之排序
数据结构·排序算法·排序·算法与数据结构
Mr_Xuhhh20 分钟前
从理论到实践:深入理解算法的时间与空间复杂度
java·开发语言·算法
6Hzlia33 分钟前
【Hot 100 刷题计划】 LeetCode 42. 接雨水 | C++ 动态规划与双指针题解
c++·算法·leetcode
地平线开发者44 分钟前
智能驾驶感知算法的演进
算法·自动驾驶
爱丽_1 小时前
B+ 树范围查询为什么快:页分裂/合并、索引设计与 SQL 写法优化
数据库·算法·哈希算法
WBluuue1 小时前
Codeforces 1087 Div2(ABCDEF)
c++·算法
Yzzz-F2 小时前
2025 ICPC武汉邀请赛 G [根号分治 容斥原理+DP]
算法
abant22 小时前
leetcode 114 二叉树变链表
算法·leetcode·链表
tankeven2 小时前
HJ165 小红的优惠券
c++·算法