[双指针] 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}; // 查找失败
    }
};
相关推荐
8Qi814 分钟前
LeetCode 1143 & 718:最长公共子序列 / 最长重复子数组
算法·leetcode·职场和发展·动态规划
绿算技术39 分钟前
万卡推理集群存储选型分析:从核心架构到应用视角
大数据·科技·算法·架构
想吃火锅10052 小时前
【leetcode】1.两数之和js版
javascript·算法·leetcode
net3m332 小时前
一阶软件低通滤波器算法
人工智能·算法
水木流年追梦3 小时前
大模型入门-大模型优化方法12-YaRN 长文本外推技术
人工智能·分布式·算法·正则表达式·prompt
J-Tony113 小时前
【JVM】三色标记法
java·jvm·算法
wengad3 小时前
机器学习实践理论基础|算法、模型和数据集
人工智能·算法·机器学习
梦梦代码精4 小时前
为什么这个开源的AI平台会火?有点东西。。。
人工智能·算法·机器学习·docker·开源
随意起个昵称5 小时前
线性dp-综合刷题1(Not Alone)
算法·动态规划