码迷,mamicode.com
首页 > 编程语言 > 详细

【leetcode 33】搜索旋转排序数组(第二遍)

时间:2020-02-10 10:05:41      阅读:48      评论:0      收藏:0      [点我收藏+]

标签:cto   color   不能   strong   tco   题解   查找   题目   排序数组   

题目链接

【题解】


如果没有旋转这么一说。
那么问题就是一道普通的二分查找的题目。
加上旋转之后。也没有让这个题变难多少。
问题的关键在于。
在二分查找的时候。
能够想到用nums[0]这个元素来确定当前二分枚举到的元素是在哪一个区间里面的。
即是在左边那个上升区间里面,还是在右边那个上升区间里面。
不过。
知道在哪个区间以后
还有一个问题。
就是我们不能单纯的就在那个区间里面做二分。
因为那个元素可能是在另外一个区间里的。
所以还得拿目标元素和nums[0]做一个对比。
比它小然后nums[mid]在左区间的话,直接l = mid+1
跑到右边那个区间去。
比它大的话然后nums[mid]在右边这个区间的话,直接r = mid-1,
跑到左边那个区间去。
这样才能不断逼近target的目标位置
总结
在写的时候,光想着判断nums[mid]在哪个区间。然后就在那个区间里面做二分了。
但是没有想到,其实target可能不在你做二分的那个区间里面的呀!

【代码】

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

【leetcode 33】搜索旋转排序数组(第二遍)

标签:cto   color   不能   strong   tco   题解   查找   题目   排序数组   

原文地址:https://www.cnblogs.com/AWCXV/p/12289738.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!