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

二分查找,lower_bound和upper_bound。

code

class Solution {
public:
    vector<int> searchRange(vector<int>& nums, int target) {
        int n=nums.size();
        int l=0,r=n-1;
        vector<int> ans(2,-1);
        while(l<=r){
            int mid=(l+r);
            if(nums[mid]==target){
                ans[0]=mid;
                r=mid-1;
            }else if(nums[mid]<target){
                l=mid+1;
            }else{
                r=mid-1;
            }
        }
        l=0,r=n-1;
        while(l<=r){
            int mid=(l+r);
            if(nums[mid]==target){
                ans[1]=mid;
                l=mid+1;
            }else if(nums[mid]<target){
                l=mid+1;
            }else{
                r=mid-1;
            }
        }
        return ans;
    }
};
原文地址:https://www.cnblogs.com/zxcoder/p/12566871.html