Leetcode数组Medium | 33. 搜索旋转排序数组

假设按照升序排序的数组在预先未知的某个点上进行了旋转。

( 例如,数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1,2] )。

搜索一个给定的目标值,如果数组中存在这个目标值,则返回它的索引,否则返回 -1 。

你可以假设数组中不存在重复的元素。

你的算法时间复杂度必须是 O(log n) 级别。

示例 1:
输入: nums = [4,5,6,7,0,1,2], target = 0
输出: 4

示例 2:
输入: nums = [4,5,6,7,0,1,2], target = 3
输出: -1

解答:
解题思路:

这道题让在旋转数组中搜索一个给定值,若存在返回坐标,若不存在返回-1。我们还是考虑二分搜索法,但是这道题的难点在于我们不知道原数组在哪旋转了,我们还是用题目中给的例子来分析,对于数组[0 1 2 4 5 6 7] 共有下列七种旋转方法:

0  1  2   4  5  6  7

7  0  1   2  4  5  6

6  7  0   1  2  4  5

5  6  7   0  1  2  4

4  5  6  7  0  1  2

2  4  5  6  7  0  1

1  2  4  5  6  7  0

二分搜索法的关键在于获得了中间数后,判断下面要搜索左半段还是右半段,我们观察上面红色加粗的数字都是升序的(前4行),由此我们可以观察出规律,如果中间的数小于最右边的数,则右半段是有序的,若中间数大于最右边数,则左半段是有序的,我们只要在有序的半段里用首尾两个数组来判断目标值是否在这一区域内,这样就可以确定保留哪半边了。

class Solution {
public:
    int search(vector<int>& nums, int target) {
        if(nums.size()<=0) //  数组为空
            return -1;
        int t1=0,t2=nums.size()-1;  //  双动态指针
        while(t1<=t2){
            int mid=(t1+t2)/2;  //  中位数
            if(nums[mid]==target)  
                return mid;
            else if(nums[mid]<nums[t2]){
                if(nums[mid]<target && nums[t2]>=target)
                    t1=mid+1; //  之所以加一是因为中位数前面已经比较过了
                else
                    t2=mid-1;
            }  //  若中位数小于最右的数,说明右半部分是有序的,先在右边查找
            else{
                if(nums[t1]<=target && nums[mid]>target)
                    t2=mid-1;
                else
                    t1=mid+1;
            } //  否则,左半部分有序,先在左边查找
        }
        return -1;  //  找不到,返回-1
    }
};

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 算法思想贪心思想双指针排序快速选择堆排序桶排序荷兰国旗问题二分查找搜索BFSDFSBacktracking分治动态...
    第六象限阅读 3,293评论 0 0
  • 假设按照升序排序的数组在预先未知的某个点上进行了旋转。 ( 例如,数组 [0,1,2,4,5,6,7] 可能变为 ...
    烛火的咆哮阅读 336评论 0 0
  • LeetCode 刷题随手记 - 第一部分 前 256 题(非会员),仅算法题,的吐槽 https://leetc...
    蕾娜漢默阅读 17,951评论 2 36
  • 今天刚看完剩下的半本书,《你的生命有什么可能》,想要一个不同的未知的未来,就想在书里找看怎么样让生命有更多的可能:...
    Lee_太白阅读 132评论 0 0
  • 亲爱的弟弟: 我决定给你写信,记下我要对你说的话。我觉得作为旁人,我不应该对你的人生有太多指画,但是作为你的朋友...
    车马正简阅读 1,127评论 0 0