题目

c++

二分

class Solution {
public:
    int search(vector<int>& nums, int target) {
        
        if(nums.size()==0)
            return -1;
        int start=0;
        int end = nums.size()-1;
        
        int ans=-1;
        while(start<end)
        {
            int mid = (start+end)/2;
            
            if(target < nums[mid])
            {
                if(target>=nums[start]&&nums[start]<nums[mid])
                {
                    end = mid-1;
                }
                else if(target<=nums[end]&&nums[end]<nums[mid])
                {
                    start = mid+1;
                }
                else
                    end=mid-1;
                
            }
            else if(target > nums[mid])
            {
                if(target>=nums[start]&&nums[start]>nums[mid])
                {
                    end = mid-1;
                }
                else if(target>=nums[end]&&nums[end]<nums[mid])
                {
                    start = mid+1;
                }
                else
                    start = mid+1;
            }
            else
            {
                ans=mid;
                break;
            }
        }
        
        if(ans!=-1)
            return ans;
        
        ans = start;
        if(nums[start]!=target)
            ans=-1;
        
        return ans;
    }
};

相关文章:

  • 2022-02-22
  • 2021-05-26
  • 2021-07-22
  • 2021-09-05
猜你喜欢
  • 2022-02-02
  • 2022-01-30
  • 2022-01-04
  • 2021-08-24
  • 2021-06-26
  • 2022-01-03
  • 2022-01-15
  • 2021-10-29
相关资源
相似解决方案