这个题的教训就是:一定要把所有的情况都写出来!不要乱用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