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

题目描述

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

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

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

解题思路:

java 复制代码
class Solution {
    public int[] searchRange(int[] nums, int target) {
        int[] res = new int[]{-1,-1};
        int left = 0;
        int right = nums.length-1;
        while(left <= right){
            int temp = (left + right) >> 1;
            if(nums[temp] > target){
                right = temp - 1;
            }else if(nums[temp] < target){
                left = temp + 1;
            }else{
                left = temp;
                right = temp;
                while((right <nums.length-1)&&(nums[right] == nums[right+1])){
                    right++;
                }
                while((left > 0)&&(nums[left] == nums[left-1])){
                    left--;
                }
                res[0] = left;
                res[1] = right;
            }

        }
        return res;
    }
}

这是最朴素的思想,二分查找,如果找到了再往两边拓展,处理边界条件,只可惜超时了。

需要对二分法再进行二分查找。

官方题解:

java 复制代码
class Solution {
    public int[] searchRange(int[] nums, int target) {
        int leftIdx = binarySearch(nums, target, true);
        int rightIdx = binarySearch(nums, target, false) - 1;
        if (leftIdx <= rightIdx && rightIdx < nums.length && nums[leftIdx] == target && nums[rightIdx] == target) {
            return new int[]{leftIdx, rightIdx};
        } 
        return new int[]{-1, -1};
    }

    public int binarySearch(int[] nums, int target, boolean lower) {
        int left = 0, right = nums.length - 1, ans = nums.length;
        while (left <= right) {
            int mid = (left + right) / 2;
            if (nums[mid] > target || (lower && nums[mid] >= target)) {
                right = mid - 1;
                ans = mid;
            } else {
                left = mid + 1;
            }
        }
        return ans;
    }
}
相关推荐
机器学习之心11 小时前
LSBoost增强算法回归预测+SHAP可解释分析+新数据预测(多输入单输出)MATLAB代码
算法·matlab·回归·lsboost·shap可解释分析
AI-Ming12 小时前
注意力机制
算法·ai·ai编程
ℳ๓₯㎕.空城旧梦12 小时前
C++中的解释器模式
开发语言·c++·算法
x_xbx12 小时前
LeetCode:2. 两数相加
算法·leetcode·职场和发展
兔子77312 小时前
RNN 终于讲明白了:从“模型为什么需要记忆”到 Elman 1990 全文吃透
算法
兔子77312 小时前
LSTM 终于讲明白了:从“RNN 为什么会忘”到 Hochreiter & Schmidhuber 1997 全文吃透
算法
ECT-OS-JiuHuaShan12 小时前
朱梁万有递归元定理,重构《阴符经》
算法·重构
_日拱一卒13 小时前
LeetCode:最长连续序列
算法·leetcode·职场和发展
2401_8795034113 小时前
C++与FPGA协同设计
开发语言·c++·算法
重生之后端学习13 小时前
287. 寻找重复数
数据结构·算法·leetcode·深度优先·图论