【LeetCode精选算法】二分查找专题二

目录

[1. 山峰数组的峰顶](#1. 山峰数组的峰顶)

[2. 寻找峰值](#2. 寻找峰值)

[3. 搜索旋转排序数组中的最小值](#3. 搜索旋转排序数组中的最小值)

[4. 0~n-1 中缺失的数字](#4. 0~n-1 中缺失的数字)


1. 山峰数组的峰顶

题目链接852. 山脉数组的峰顶索引
解题思路

  • 使用二分查找,找到满足 arr[mid] > arr[mid - 1] 的最后一个位置。

  • 如果 arr[mid] > arr[mid - 1],说明还在上升阶段,答案在 [mid, right]

  • 否则说明已经过了峰顶,答案在 [left, mid - 1]

  • 最后返回 left

Java 代码

java 复制代码
class Solution {
    public int peakIndexInMountainArray(int[] arr) {
        int left = 1, right = arr.length - 2;
        while (left < right) {
            int mid = left + (right - left + 1) / 2;
            if (arr[mid] > arr[mid - 1]) {
                left = mid;
            } else {
                right = mid - 1;
            }
        }
        return left;
    }
}

2. 寻找峰值

题目链接162. 寻找峰值
解题思路

  • 利用"任意相邻元素不相等"和"两端视为负无穷"的条件。

  • 比较 arr[mid]arr[mid + 1]

    • 如果 arr[mid] < arr[mid + 1],说明右侧存在峰值,left = mid + 1

    • 否则说明左侧存在峰值,right = mid

  • 最终返回 left

Java 代码

java 复制代码
class Solution {
    public int findPeakElement(int[] nums) {
        int left = 0, right = nums.length - 1;
        while (left < right) {
            int mid = left + (right - left) / 2;
            if (nums[mid] < nums[mid + 1]) {
                left = mid + 1;
            } else {
                right = mid;
            }
        }
        return left;
    }
}

3. 搜索旋转排序数组中的最小值

题目链接153. 寻找旋转排序数组中的最小值
解题思路

  • 将数组最后一个元素 x 作为参照点。

  • 比较 nums[mid]x

    • 如果 nums[mid] > x,说明 mid 在旋转点左侧,最小值在右侧,left = mid + 1

    • 否则说明 mid 在旋转点右侧或就是最小值,right = mid

  • 最后返回 nums[left]

Java 代码

java 复制代码
class Solution {
    public int findMin(int[] nums) {
        int left = 0, right = nums.length - 1;
        int x = nums[right];
        while (left < right) {
            int mid = left + (right - left) / 2;
            if (nums[mid] > x) {
                left = mid + 1;
            } else {
                right = mid;
            }
        }
        return nums[left];
    }
}

4. 0~n-1 中缺失的数字

题目链接剑指 Offer 53-II. 0~n-1中缺失的数字
解题思路

  • 在缺失位置之前,nums[i] == i;之后,nums[i] != i

  • 比较 nums[mid]mid

    • 如果 nums[mid] == mid,说明缺失位置在右侧,left = mid + 1

    • 否则说明缺失位置在左侧或当前位置,right = mid

  • 最后判断 nums[left] 是否等于 left,决定返回 left + 1 还是 left

Java 代码

java 复制代码
class Solution {
    public int missingNumber(int[] nums) {
        int left = 0, right = nums.length - 1;
        while (left < right) {
            int mid = left + (right - left) / 2;
            if (nums[mid] == mid) {
                left = mid + 1;
            } else {
                right = mid;
            }
        }
        return nums[left] == left ? left + 1 : left;
    }
}
相关推荐
空空kkk5 小时前
Java项目从单体到微服务的演变
java·运维·微服务
程农5 小时前
java计算机毕业设计婚纱摄影网站(附源码、数据库)
java·数据库·课程设计
BlockChain8885 小时前
Spring框架终极入门指南(12000字深度解析)
java·后端·python·spring
We་ct5 小时前
LeetCode 42. 接雨水:双指针解法深度剖析与全方法汇总
前端·算法·leetcode·typescript
液态不合群5 小时前
如何提升 C# 应用中的性能
开发语言·算法·c#
诗远Yolanda5 小时前
EI国际会议-通信技术、电子学与信号处理(CTESP 2026)
图像处理·人工智能·算法·计算机视觉·机器人·信息与通信·信号处理
青云交5 小时前
Java 大视界 -- Java 大数据实战:分布式架构重构气象预警平台(2 小时→2 分钟)
java·java 大数据 气象预警平台·flink 实时数据清洗·spark 区域定制模型·气象灾害预警系统
柏林以东_5 小时前
异常的分类与用法
java·开发语言
程序员-King.5 小时前
day165—递归—最长回文子序列(LeetCode-516)
算法·leetcode·深度优先·递归