[LeetCode]Search for a range

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].code

For 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;
    }
};
相關文章
相關標籤/搜索