两数之和 II(输入有序数组)——双指针那点儿事儿

两数之和 II(输入有序数组)——双指针那点儿事儿

大家好,今天咱聊一道非常经典而且非常“干净利落”的题:两数之和 II - 输入有序数组。这题在 LeetCode 上是 Two Sum II - Input array is sorted,给定一个已排序的数组 numbers 和一个目标值 target,找出两个数使得它们相加等于 target,返回它们的下标(通常是 1-based)。看起来完全是套路题,但它能帮你把双指针思想吃透——这是做算法题的基础功。

下面我把思路、代码、复杂度、细节和踩坑点都讲清楚,像咱平时聊天那样直白易懂。


一、双指针的直觉(为什么有效?)

数组是排好序的,这点很重要。设左右指针 l 指向开头,r 指向结尾:

  • 如果 numbers[l] + numbers[r] == target,恭喜,找到答案;
  • 如果和比 target 大,说明右边太大了,应该把 r 左移(减小和);
  • 如果和比 target 小,说明左边太小了,应该把 l 右移(增大和)。

这个思路利用的是

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Echo_Wish

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值