34. 在排序数组中查找元素的第一个和最后一个位置

题目分析

这个题目拆分为left_boundright_bound比较容易理解.
虽然代码量有冗余.

class Solution(object):
    def left_bound(self, nums, target):
        low = 0
        high = len(nums)-1
        res = []
        while low<=high:
            mid = low + (high-low)/2
            if(nums[mid] < target):
                low = mid+1
            elif(nums[mid]>target):
                high = mid-1
            elif nums[mid] == target:
                if mid == 0 or nums[mid-1]<target:
                    return mid
                high = mid -1
        return -1
    
    def right_bound(self, nums, target):
        low = 0
        high = len(nums)-1
        res = []
        while low<=high:
            mid = low + (high-low)/2
            if(nums[mid] < target):
                low = mid+1
            elif(nums[mid]>target):
                high = mid-1
            elif nums[mid] == target:
                if mid == len(nums)-1 or nums[mid+1]>target:
                    return mid
                low = mid +1
        return -1
    def searchRange(self, nums, target):
        """
        :type nums: List[int]
        :type target: int
        :rtype: List[int]
        """

        left = self.left_bound(nums,target)
        right = self.right_bound(nums,target)
        return [left,right]

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容