Given a sorted array of integers, find the starting and ending position of a given target value.數組
Your algorithm's runtime complexity must be in the order of O(log n).spa
If the target is not found in the array, return
[-1, -1]
.codeFor example,
Given[5, 7, 7, 8, 8, 10]
and target value 8,
return[3, 4]
.blog
題目要求:查找有序數組,找到target的範圍,若是target不存在於數組,返回[-1, -1]。get
思路:和二分查找的思路相似,找到target以後,將start和end同時指向mid,終止查找。而後start向左搜索,end向右搜索,定位區間。it
注意start和end下標不要越界的問題(第一次WA就是由於這個錯誤)。io
代碼class
class Solution { public: vector<int> searchRange(int A[], int n, int target) { // Note: The Solution object is instantiated only once and is reused by each test case. vector<int> range; if(n==0 || A==NULL) { range.push_back(-1); range.push_back(-1); return range; } int l=0, r=n-1, start=-1, end=-1; int mid = 0; bool success_flag = false; while(l<=r) { mid = (l+r)/2; if(A[mid] == target) { start = mid; end = mid; success_flag = true; break; } else{ if(A[mid]>target) // ture left { r = mid-1; } else l = mid+1; } } // search range if(success_flag) { while(A[start-1]==target && start>0) --start; while(A[end+1] == target && end<n-1) ++end; } range.push_back(start); range.push_back(end); return range; } };