【题目描述】
给你一个按照非递减顺序排列的整数数组 nums,和一个目标值 target。请你找出给定目标值在数组中的开始位置和结束位置。
如果数组中不存在目标值 target,返回 [-1, -1]。
你必须设计并实现时间复杂度为 O(log n) 的算法解决此问题。
【代码】
二分查找位置再遍历(其实遍历也可以二分)
class Solution {
public:
int binarySearch(vector<int>& nums, int target) {
int left = 0, right = (int)nums.size() - 1;
while (left < right) {
int mid = (left + right) / 2;
if (nums[mid]==target) return mid;
if (nums[mid] > target) {
right = mid - 1;
} else {
left = mid+1;
}
}
if (left>right) return -1;
if (nums[left]==target) return left;
return -1;
}
vector<int> searchRange(vector<int>& nums, int target) {
int index=binarySearch(nums,target);
if (index==-1) return vector<int>{-1, -1};
int l,r,n=nums.size();
l=index;
while (l>0 && nums[l-1]==nums[l]) l--;
r=index;
while (r<n-1 && nums[r+1]==nums[r]) r++;
return vector<int>{l, r};
}
};