题目:
给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。
要求:
算法时间复杂度必须是 O(log n) 级别。
如果数组中不存在目标值,返回 [-1, -1]。
class Solution {
public:
vector<int> searchRange(vector<int>& nums, int target) {
vector<int> res(2, -1);
if(nums.size() == 0) return res;
int left = 0, right = nums.size() - 1;
int mid = (left + right) / 2;
while (nums[mid] != target){
if (nums[mid] > target){
right = mid - 1;
}
else{
left = mid + 1;
}
mid = (left + right) / 2;
if (left > right) return res;
}
left = right = mid;
while (left >= 0 && nums[left] == target) left--;
res[0] = left + 1;
while (right < nums.size() && nums[right] == target) right++;
res[1] = right - 1;
return res;
}
};
题解:
采用二分法先将目标值的位置找到,然后根据这个位置向左向右查找,找到最左端位置为元素的第一个位置,最右边端位置为元素的最后一个位置。
需要注意查找最左端最右端的位置时,left 多减了一次,right 多加了一次。