二分查找巧解数组范围问题

数的范围题解(Java实现)

问题描述

给定一个升序排列的整数数组 arr 和目标值 k,要求找出 k 在数组中出现的起始位置和结束位置(从0开始计数)。若 k 不存在,则返回 [-1, -1]

算法思路

使用二分查找的变形:

  1. 左边界查找:找到第一个 \\geq k 的位置 \\text{while } l \< r \\text{ 时}, \\quad mid = l + r \>\> 1 \\text{若 } arr\[mid\] \\geq k, \\text{ 则 } r = mid \\text{否则 } l = mid + 1
  2. 右边界查找:找到最后一个 \\leq k 的位置 \\text{while } l \< r \\text{ 时}, \\quad mid = l + r + 1 \>\> 1 \\text{若 } arr\[mid\] \\leq k, \\text{ 则 } l = mid \\text{否则 } r = mid - 1
代码实现
java 复制代码
import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt(), q = sc.nextInt();
        int[] arr = new int[n];
        for (int i = 0; i < n; i++) arr[i] = sc.nextInt();
        
        while (q-- > 0) {
            int k = sc.nextInt();
            int l = 0, r = n - 1;
            
            // 左边界查找
            while (l < r) {
                int mid = l + r >> 1; // 向下取整
                if (arr[mid] >= k) r = mid;
                else l = mid + 1;
            }
            
            // 未找到目标值
            if (arr[l] != k) {
                System.out.println("-1 -1");
                continue;
            }
            
            int left = l;
            r = n - 1; // 重置右指针
            
            // 右边界查找
            while (l < r) {
                int mid = l + r + 1 >> 1; // 向上取整
                if (arr[mid] <= k) l = mid;
                else r = mid - 1;
            }
            
            System.out.println(left + " " + l);
        }
    }
}
关键点说明
  1. 左边界查找 :通过 mid = l + r >> 1 确保左指针能推进
  2. 右边界查找 :通过 mid = l + r + 1 >> 1 避免死循环
  3. 边界验证 :左边界查找后需检查 arr[l] == k
  4. 时间复杂度O(\\log n) 每次查询
示例测试

输入:

复制代码
6 3
1 2 2 2 3 4
2
3
4

输出:

复制代码
1 3
4 4
5 5
相关推荐
她的男孩18 小时前
Spring Boot 接 Flowable 工作流:用 3 个注解搭一个请假审批流程
java·后端·架构
复杂网络19 小时前
多个 Claude Code 与多个 Codex 协同工作:设计与实现方案
算法
荣码19 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
plainGeekDev21 小时前
Gson → kotlinx.serialization
android·java·kotlin
小bo波1 天前
Java Swing 图形用户界面实验 —— 从算术练习到游戏开发的完整实践
java·课程设计·gui·游戏开发·扫雷·swing
咖啡八杯1 天前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
HjhIron1 天前
面试常客:字符串算法从入门到进阶
算法·面试
吴佳浩1 天前
DeepSeek DSpark:Confidence-Scheduled Speculative Decoding 技术解析
人工智能·算法·deepseek