leetcode刷题(python)--33. Search in Rotated Sorted Array(思路以及两种解法-迭代和递归)

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).

思路:

需要使用二分法的变体:

这里的数组是首先从小到大排序,然后经过绕着某个轴旋转,比如[0,1,2,4,5,6,7]旋转后得到[4,5,6,7,0,1,2]

那么没法直接使用二分法,我们这里注意到数组之前是从小到大排序的,因为需要输出目标值的索引,那么我们不能去修改那么使用三个flag: left, mid, right

来记录每一次需要搜索的左边界,中间点和右边界:

首先确定边界,不管是递归还是迭代,必须保证left <= right, 在这个前提下,

因为没有重复项,每次搜索前先查看nums[left], nums[mid], nums[right],

若与目标值相等:直接返回

若不相等:

        1.比较nums[mid]和nums[right]:

                如果nums[mid] < nums[right],说明(mid, right)是有序的:

                            如果target属于区间(mid, right),就在这个区间接着搜索,重复之前步骤;

                            如果target不属于区间(mid, right),就在(left, mid)接着搜索,重复之前步骤;

                如果nums[mid] > nums[right],

                如果nums[mid] < nums[right],说明(left, mid)是有序的:

                            如果target属于区间(left, mid),就在这个区间接着搜索,重复之前步骤;

                            如果target不属于区间(left, mid),就在(mid, right)接着搜索,重复之前步骤;

Example 1:

Input: nums = [4,5,6,7,0,1,2], target = 0
Output: 4

Example 2:

Input: nums = [4,5,6,7,0,1,2], target = 3
Output: -1
[python]  view plain   copy
  1. class Solution:  
  2.     def search(self, nums, target):  
  3.         """ 
  4.         :type nums: List[int] 
  5.         :type target: int 
  6.         :rtype: int 
  7.         """  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值