首页 > 其他 > 详细

LeetCode 33 Search in Rotated Sorted Array

时间:2019-07-22 20:20:57      阅读:113      评论:0      收藏:0      [点我收藏+]

题目

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;
    }
};

LeetCode 33 Search in Rotated Sorted Array

原文:https://www.cnblogs.com/dacc123/p/11228085.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!