[双指针] 6. 查找总价为目标值的两个商品

题目链接

https://leetcode.cn/problems/he-wei-sde-liang-ge-shu-zi-lcof/

一. 题目描述

cpp 复制代码
class Solution {
public:
    vector<int> twoSum(vector<int>& price, int target) {
        
    }
};

二. 解题思路

  1. 本题利用单调性和双指针,是非常简单的一道题。

其实就是根据单调性,大了左往走,小了往右走,相等就返回。

  1. 需要注意的是,要为找不到的情况随便返回一个值(走不到这条语句)。这道题的测试用例都是一定能找到一对相加等于target的值的,但是力扣平台不允许出现可能某条路径没有返回值。我们知道前两条判断只是过程最终一定会走到else语句返回一组值,但是平台认为如果在if或者else if结束了会没有返回值,所以我们在最后添加return {-1, -1}; // 隐式类型转换

三. 代码实现

cpp 复制代码
class Solution 
{
public:
    vector<int> twoSum(vector<int>& price, int target) 
    {
        int left = 0, right = price.size()-1;
        while(left < right)
        {
            if(price[left] + price[right] < target)
                left++;
            else if(price[left] + price[right] > target)
                right--;
            else
                return {price[left], price[right]};
        }
        return {-1, -1}; // 查找失败
    }
};
相关推荐
一路向北he2 小时前
esp32库依赖
c语言·c++·算法
人间寥寥情难诉2 小时前
LRU算法本地实现
java·算法·spring
moonsea02032 小时前
2026.4.2
开发语言·c++·算法
cpp_25012 小时前
P10376 [GESP202403 六级] 游戏
c++·算法·动态规划·题解·洛谷·gesp六级
智者知已应修善业2 小时前
【51单片机4个IO实现16按键可扩展独立按键64矩阵驱动显示矩阵原值】2023-5-8
c++·经验分享·笔记·算法·51单片机
hui-梦苑2 小时前
[GROMACS]模拟数据分析前轨迹文件生成-轨迹预处理
人工智能·算法·数据分析
蒸汽求职2 小时前
低延迟系统优化:针对金融 IT 与高频交易,如何从 CPU 缓存行(Cache Line)对齐展现硬核工程底蕴?
sql·算法·缓存·面试·职场和发展·金融·架构
田梓燊2 小时前
leetcode 239
数据结构·算法·leetcode
CoderCodingNo10 小时前
【NOIP】2011真题解析 luogu-P1003 铺地毯 | GESP三、四级以上可练习
算法