二分查找一>:在排序数组中查找元素的第一个和最后一个位置

1.题目:

2.解析:这里不能用传统二分,因为涉及范围,传统二分时间复杂度会降为O(N),要做些改动。

步骤一:查找区间左端点

细节图:

步骤二:查找区间右端点:

细节图:

代码:

java 复制代码
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;
        int 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){
            ret[0] = left;
        }else {
            return ret;
        }

        //二分查找区间右端点
        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;
    }

3.非朴素二分模板:在理解原理基础上

相关推荐
kitesxian19 分钟前
Leetcode207. 课程表(HOT100)
数据结构
明月*清风27 分钟前
【数据结构专栏】二叉搜索树(Binary Search Tree)的剖析?
开发语言·数据结构·c++·visualstudio
Beau_Will28 分钟前
数据结构-树状数组专题(2)
数据结构·c++·算法
济南信息学奥赛刘老师1 小时前
GESP考试大纲
开发语言·c++·算法·青少年编程
~yY…s<#>1 小时前
【刷题21】BFS解决FloodFill算法专题
数据结构·c++·算法·leetcode·宽度优先
九圣残炎1 小时前
【从零开始的LeetCode-算法】3297. 统计重新排列后包含另一个字符串的子字符串数目 I
java·算法·leetcode
无限大.1 小时前
力扣题解 3233. 统计不是特殊数字的数字数量(中等)
算法·leetcode·职场和发展
sid_Tang1 小时前
算法的空间复杂度
数据结构
edward13461 小时前
[JLOI2014] 松鼠的新家(重链剖分+线段树)
数据结构·c++·算法
liujjjiyun1 小时前
小U数数问题
c++·算法