[算法导论] 两数之和小于目标值a+b<=target, 二分+指针o(nlogn)

这篇博客介绍了如何利用二分查找和指针技术,在数组 `[1, 2, 6, 9]` 中找到两数之和小于给定目标值 `6` 的组合,例如 `1+2`。" 132888995,8753399,JavaScript实现单板密码算法,"['javascript', '算法', '开发语言']
摘要由CSDN通过智能技术生成

[1,2,6,9] 6

1+2

一种组合

lt =input()[1:].split(']')
l = list(map(int,lt[0].split(',')))
m = int(lt[1].split(',')[-1])
MAX = 1e9+7
n = len(l)
c = 0
l.sort()
r = n-1 # r不用每次都赋初始值!因为排序后,i增加,右边界肯定<=r。
#!!!!!!!!!!!!!!!!!二分+指针,nlogn
for i in range(n):
    if i >= r:
        break
    # 二分寻找右边界 r为上次遍历的右边界。这次的右边界<=上次的右边界。
    mid = r
    while i < mid: # 为什么是<=,不是<, 因为r = (r + i) // 2时,i可能=r
        if mid == n-1 and l[i]+l[mid] <= m: #注意mid==n-1的判断要写在前面,否则后面越界。
            break
        if mid < n-1 and l[i] + l[mid] <= m < l[i]+l[mid + 1]:#找到右边界 注意mid==n-1的判断要写在前面,否则后面越界。
            break
        elif l[i]+l[mid] <= m: ### 增大mid,右区间。
            mid = (mid+1+r)//2 # 这里用到上次更新的右边界。
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

心心喵

喵喵(*^▽^*)

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值