LCP167 两数之和II--输入有序数组[leetcode-5]

LCP167 两数之和II--输入有序数组

给你一个下标从 1 开始的整数数组 numbers ,该数组已按 非递减顺序排列 ,请你从数组中找出满足相加之和等于目标数 target 的两个数。如果设这两个数分别是 numbers[index1]numbers[index2] ,则 1 <= index1 < index2 <= numbers.length

以长度为 2 的整数数组 [index1, index2] 的形式返回这两个整数的下标 index1index2

你可以假设每个输入 只对应唯一的答案 ,而且你 不可以 重复使用相同的元素。

你所设计的解决方案必须只使用常量级的额外空间。

示例 1:

复制代码
输入:numbers = [2,7,11,15], target = 9
输出:[1,2]
解释:2 与 7 之和等于目标数 9 。因此 index1 = 1, index2 = 2 。返回 [1, 2] 。
题解

输入本身有序,推荐使用双指针。结果看来是1基数的,在算法阶段使用0基数,返回1基数即可

代码
CPP 复制代码
class Solution {
public:
    vector<int> twoSum(vector<int>& numbers, int target) {
    //这题的性质很好,字迹从小到大
    //使用双指针法,也称滑动窗口
    int l=0;
    int r=numbers.size()-1;
    int sum;
    while(l<r)
    {
        sum=numbers[l]+numbers[r];//计算和
           //注意答案要求的是1基数形式
        if(sum==target)   return {l + 1, r + 1}; // 返回1基数的索引;

        if(sum>target) --r;   //SUM偏大,则左移右指针,让总结果变小
        if(sum<target) ++l;		SUM偏小,则右移左指针,让总结果变大
    }

   //实际上按照题设,这里不可能到达,但是LEETCODE很奇怪,它必须要一个显式的返回值
    return{};
    }
};

结果排名

很遗憾啊,没有100%

相关推荐
CoovallyAIHub18 分钟前
YOLO26-Pose 深度解读:端到端架构重新设计,姿态估计凭什么跨代领先?
深度学习·算法·计算机视觉
CoovallyAIHub42 分钟前
化工厂气体泄漏怎么用AI检测?30张图3D重建气体泄漏场景——美国国家实验室NeRF新研究
深度学习·算法·计算机视觉
颜酱12 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
zone773918 小时前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试
CoovallyAIHub20 小时前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub20 小时前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉
CoovallyAIHub21 小时前
Claude Code 突然变成了 66 个专家?这个 5.8k Star 的开源项目,让我重新理解了什么叫"会用 AI"
深度学习·算法·计算机视觉
兆子龙21 小时前
前端哨兵模式(Sentinel Pattern):优雅实现无限滚动加载
前端·javascript·算法
xlp666hub1 天前
Leetcode第五题:用C++解决盛最多水的容器问题
linux·c++·leetcode
CoovallyAIHub1 天前
9个视觉语言模型工厂实测:Qwen 87.9%碾压全场,你的显卡能跑哪个?
算法