【算法专题】双指针算法之LCR 179. 查找总价格为目标值的两个商品(力扣)

欢迎来到 CILMY23的博客

🏆本篇主题为:双指针算法之LCR 179. 查找总价格为目标值的两个商品(力扣)

🏆个人主页:CILMY23-CSDN博客

🏆系列专栏:Python | C++ | C语言 | 数据结构与算法 | 贪心算法 | Linux | 算法专题 | 代码训练营

🏆感谢观看,支持的可以给个一键三连,点赞收藏+评论。如果你觉得有帮助,还可以点点关注


题目:

LCR 179. 查找总价格为目标值的两个商品 - 力扣(LeetCode)

购物车内的商品价格按照升序记录于数组 price。请在购物车中找到两个商品的价格总和刚好是 target。若存在多种情况,返回任一结果即可。

示例:

一、题目解析

根据题目给出的信息一共有以下几点:

1.price数组中的数据是升序排列

2.在数组中找两个数求和

3.存在多种情况,返回任一结果即可 --->找一个结果就行

4.情况中可能没有结果

在之前的磨练里,这种要找两个数,并且求和的,它是需要两个指针,所以这题为双指针算法

二、算法原理

这题的解法跟之前的几篇写过的原理相似。

我们可以先想想暴力破解是如何做的:

这题双循环,然后给它记录下来,一个数一个数的遍历过去,这样暴力破解的思路大致清晰了。

因为存在多种情况,返回任一结果即可 --->找一个结果就行。

暴力破解的复杂度是O(n^2),我们可以采用双指针算法来减少空间复杂度达到O(n)。

解析:

我们让一个left指向第一个数,right指向第二个数,如果他们加起来和target 给的数相等,那么我们就返回这两个数。

假设 left + right < 18,那说明left太小了,可以增加left的值,因为数组是单调递增,所以先增加最小的值,故让left++。

假设 left + right > 18,那说明right太小了,可以增加right的值,因为数组是单调递增,所以先减小最大的值,故让right--。

那如果没有结果,我们就返回一个{}就可以了。

三、代码编写

cpp 复制代码
class Solution 
{
public:
    vector<int> twoSum(vector<int>& price, int target)
    {
        int left = 0;
        int right = price.size() -1;
        while(left < right)
        {
            if(price[left] + price[right] == target )
            {
                return {price[left],price[right]};
            }
            else if(price[left] + price[right] < target)
            {
                left++;
            }
            else if(price[left] + price[right] > target)
            {
                right--;
            }
        }
        return {};
    }
};

🛎️感谢各位同伴的支持,本期C++算法专题就讲解到这啦,下期我们将详解三数之和,如果你觉得写的不错的话,可以给个一键三连,点赞,收藏+评论,可以的话还希望点点关注,若有不足,欢迎各位在评论区讨论。

相关推荐
可涵不会debug几秒前
C语言文件操作:标准库与系统调用实践
linux·服务器·c语言·开发语言·c++
凭君语未可3 分钟前
豆包MarsCode:小C点菜问题
算法
C语言魔术师23 分钟前
【小游戏篇】三子棋游戏
前端·算法·游戏
自由自在的小Bird23 分钟前
简单排序算法
数据结构·算法·排序算法
刘好念27 分钟前
[OpenGL]实现屏幕空间环境光遮蔽(Screen-Space Ambient Occlusion, SSAO)
c++·计算机图形学·opengl·glsl
C嘎嘎嵌入式开发2 小时前
什么是僵尸进程
服务器·数据库·c++
王老师青少年编程7 小时前
gesp(C++五级)(14)洛谷:B4071:[GESP202412 五级] 武器强化
开发语言·c++·算法·gesp·csp·信奥赛
DogDaoDao7 小时前
leetcode 面试经典 150 题:有效的括号
c++·算法·leetcode·面试··stack·有效的括号
Coovally AI模型快速验证8 小时前
MMYOLO:打破单一模式限制,多模态目标检测的革命性突破!
人工智能·算法·yolo·目标检测·机器学习·计算机视觉·目标跟踪
一只小bit8 小时前
C++之初识模版
开发语言·c++