标签:target nums int mid else 数组 我学 leetcode33 AndyJ
这个题的教训就是:一定要把所有的情况都写出来!不要乱用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
标签:target,nums,int,mid,else,数组,我学,leetcode33,AndyJ 来源: https://blog.csdn.net/mianjiong2855/article/details/106724755
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。