您的位置:首页 > 其它

leetcode -- Search for a Range -- 思路简单,要再做一遍

2015-12-14 20:54 477 查看
https://leetcode.com/problems/search-for-a-range/

参考

/article/4981605.html

思路 就是BS mid找到target之后,再左右搜索边界即可.

class Solution(object):
def searchRange(self, nums, target):
"""
:type nums: List[int]
:type target: int
:rtype: List[int]
"""
left = 0; right = len(nums) - 1
while left <= right:
mid = (left + right) / 2
if nums[mid] > target:
right = mid - 1
elif nums[mid] < target:
left = mid + 1
else:
list = [0, 0]
#这里注意加上下面这两句,对应的case是[2,2],target = 2
if nums[left] == target: list[0] = left
if nums[right] == target: list[1] = right
for i in range(mid, right+1):
if nums[i] != target: list[1] = i - 1; break
for i in range(mid, left-1, -1):
if nums[i] != target: list[0] = i + 1; break
return list
return [-1, -1]
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: