[Med Bi-Div] 33. Search in Rotated Sorted Array

Description

Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand.

(i.e., [0,1,2,4,5,6,7] might become [4,5,6,7,0,1,2]).

You are given a target value to search. If found in the array return its index, otherwise return -1.

You may assume no duplicate exists in the array.

Your algorithm's runtime complexity must be in the order of O(log n).

Solution

二分法,分情况处理
(类似题目:找min)

class Solution:
    def search(self, nums: List[int], target: int) -> int:
        if len(nums)==0:
            return -1
        start = 0
        end = len(nums)-1
        
        while start+1<end:
            mid = (start+end)//2
            if nums[mid]>nums[start]:
                if target >= nums[start] and target <=nums[mid]: 
                    end = mid
                else:
                    start = mid
            else:
                if target <= nums[end] and target >=nums[mid]: 
                    start = mid 
                else:
                    end = mid
        if target == nums[start]:
            return start
        if target == nums[end]:
            return end
        
        return -1     
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容