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%

相关推荐
拼好饭和她皆失1 分钟前
高效算法的秘诀:滑动窗口(尺取法)全解析
数据结构·算法·滑动窗口·尺取法
断剑zou天涯12 分钟前
【算法笔记】二叉树的Morris遍历
数据结构·笔记·算法
元亓亓亓14 分钟前
LeetCode热题100--739. 每日温度--中等
python·算法·leetcode
小白程序员成长日记16 分钟前
2025.12.11 力扣每日一题
数据结构·算法·leetcode
一碗白开水一17 分钟前
【论文阅读】Denoising Diffusion Probabilistic Models (DDPM)详细解析及公式推导
论文阅读·人工智能·深度学习·算法·机器学习
代码游侠22 分钟前
学习笔记——进程
linux·运维·笔记·学习·算法
天赐学c语言25 分钟前
12.11 - 最长回文子串 && main函数是如何开始的
c++·算法·leetcode
CoovallyAIHub26 分钟前
AI模型训练有哪些关键步骤与必备工具?从概念到可运行的智能模型
深度学习·算法·计算机视觉
程序员-King.30 分钟前
day122—二分查找—完成旅途的最少时间(LeetCode-2187)
算法·leetcode·二分查找·双指针
暗之星瞳30 分钟前
线性回归+实例
算法·回归·线性回归