跟着专注于计算机视觉的AndyJ的妈妈我学算法之每日一题leetcode33搜索旋转排序数组

这个题的教训就是:一定要把所有的情况都写出来!不要乱用else,太危险了。。。要考虑边界情况。
另一个教训。牢记左闭右闭规则,while小于等于规则,mid+1-1规则。这三点。牢记。然后循环中,不要乱用else,认真考虑,多刷题,嗯,差不多这个样子。

题目:

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

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

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

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

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

直接写代码:
双指针,这个链接的图真好,引用一下:
链接: 二分查找.
好了,相信看这个也看懂了。注意,我们判断的永远是,或者说需要的永远是,那个单调的区间,其他的用else代替。这个很重要。
python代码如下:

class Solution(object):
    def search(self, nums, target):
        """
        :type nums: List[int]
        :type target: int
        :rtype: int
        """
        l = 0
        r = len(nums)-1
        while l<=r:
            mid = l+(r-l)//2
            if nums[mid]==target:
                return mid
            if nums[l]<nums[mid]:
                if nums[l]<=target and nums[mid]>target:
                    r = mid-1
                else:
                    l = mid+1
            elif nums[l]>nums[mid]:
                if nums[r]>=target and nums[mid]<target:
                    l = mid+1
                else:
                    r = mid-1
            else:
                l = mid+1
        return -1
上一篇:Centos7上部署openstack mitaka配置详解(将疑难点都进行划分)


下一篇:从0开始学算法--基础算法(3.4分块)