[双指针] 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}; // 查找失败
    }
};
相关推荐
Felven5 分钟前
B. Make Almost Equal With Mod
数据结构·算法
脆皮炸鸡7556 分钟前
Linux~~基础IO
linux·运维·服务器·经验分享·算法·学习方法
colofullove12 分钟前
文本分块策略与预处理
算法
三毛的二哥13 分钟前
BEV:感知抖动问题及解决办法
人工智能·算法·计算机视觉
AI科技星13 分钟前
宇宙终极几何:莫比乌斯光速螺旋统一理论-精细结构常数α本源结构
算法·机器学习·数学建模·数据挖掘·量子计算
Via_Neo27 分钟前
区间dp算法
开发语言·javascript·算法
amcomputer27 分钟前
简单总结拉格朗日乘数法
算法
hi_ro_a29 分钟前
C++ 手撕 STL 底层:红黑树封装 mymap/myset
数据结构·c++·算法
tankeven38 分钟前
贪心算法(Greedy Algorithm)详解:从理论到C++实践
c++·算法
Hesionberger38 分钟前
LeetCode72.编辑距离(多维动态规划)
java·开发语言·c++·python·算法