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

本文介绍了如何通过定义边界值和分情况讨论的方法来解决LeetCode中的二分类问题,涉及getLeftBorder和getRightBorder函数,针对target不在、在内但不存在和在内且存在的三种情况求解数组边界。
摘要由CSDN通过智能技术生成

题目链接:. - 力扣(LeetCode)

属于数组问题,该问题为二分类问题,也是需要找到循环不变量边界来进行解题。

首先将题目进行分情况讨论,共有以下三种情况:

1.target不在数组所包含的范围内,target比左边界小或者比右边界大。

2.target在数组所包含的范围内,但数组中不存在该数值。

3.target在数组所包含的范围内且数组中存在该值。

根据以上三种情况,可以首先定义所对应的边界值,然后在进行归类判断。

首先是判断左边界,需要注意的是:在进行寻找左边界时,target是在数组范围的右边,才会有左边界。

def getLeftBorder(nums: List[int], target: int) -> int:
            right = len(nums) - 1
            left = 0
            leftBorder = -2
            while left <= right:
                mid = left + (right - left) // 2
                if nums[mid] >= target:
                    right = mid - 1
                    leftBorder = right
                    
                else:
                    left = mid + 1
                    
            return leftBorder

同理,判断右边界时,target在数组的左边,才会有右边界。

        def getRightBorder(nums: List[int], target: int) -> int:
            right = len(nums) - 1
            left = 0
            rightBorder = -2
            while left <= right:
                mid = left + (right - left) // 2
                if nums[mid] > target:
                    right = mid - 1       
                else:
                    left = mid + 1
                    rightBorder = left
            
            return rightBorder

根据所得出的左右边界值再进行分情况讨论即可。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值