[Leetcode] 33. 搜索旋转排序数组

2020-04-27  本文已影响0人  丶噗噗噗噗噗

33. 搜索旋转排序数组

来源: 33. 搜索旋转排序数组

1. 解题思路

二分法查找

2. 代码

class Solution:
    def search(self, nums: List[int], target: int) -> int:
        if len(nums) == 0:
            return -1
        left, right = 0, len(nums)-1
        while left + 1 < right:
            mid = (left + right) // 2
            if nums[mid] == target:
                return mid
            if nums[left] < nums[mid]:
                if nums[left] <= target and target <= nums[mid]:
                    right = mid
                else:
                    left = mid
            else:
                if nums[mid] <= target and target <= nums[right]:
                    left = mid
                else:
                    right = mid
        if nums[left] == target:
            return left
        if nums[right] == target:
            return right
        return -1
上一篇 下一篇

猜你喜欢

热点阅读