微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

leetcode个人题解——#34 Find First and Last Position of Element in Sorted Array

思路:先二分查找到一个和target相同的元素,然后再左边二分查找左边界,右边二分查找有边界。

class Solution {
public:
    int begin  = -1,end = -1;
    int ends;
    int lSearch(int left,int right,vector<int>& nums,int target)
    {
        if(left > right) return -1;
        int mid = (left + right) / 2;
        if(nums[mid] == target){
            if(mid == 0 || (mid > 0 && nums[mid - 1] < target)) return mid;
            else return lSearch(left,mid - 1,nums,target);
        }else
            return lSearch(mid + 1,right,target);
        return -1;
    }
    
    int rSearch(int left,int target)
    {
        if(left > right) return -1;
        int mid = (left + right) / 2;
        if(nums[mid] == target){
            if(mid == ends || (mid < ends && nums[mid + 1] > target)) return mid;
            else return rSearch(mid + 1,target);
        }else
            return rSearch(left,target);
        return -1;
    }
    
    int midSearch(int left,int target)
    {
        if(left > right) return -1;
        int mid = (left + right) / 2;
        if(nums[mid] == target){
            return mid;
        } 
        else if(nums[mid] < target) return midSearch(mid + 1,target);
        else if(nums[mid] > target) return midSearch(left,target);
        return -1;
    }
    
    vector<int> searchRange(vector<int>& nums,int target) {
        ends = nums.size() - 1;
        int mid = midSearch(0,ends,target);
        if(mid != -1){
        begin = lSearch(0,mid,target);
        end = rSearch(mid,target);
        }
        vector<int> ans;
        ans.push_back(begin);
        ans.push_back(end);
        return ans;
    }
};

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。