每日一练【查找总价格为目标值的两个商品】

一、题目描述

题目链接

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

示例 1:

复制代码
输入:price = [3, 9, 12, 15], target = 18
输出:[3,15] 或者 [15,3]

示例 2:

复制代码
输入:price = [8, 21, 27, 34, 52, 66], target = 61
输出:[27,34] 或者 [34,27]

二、题目解析

注意题目中的关键字------有序数组,但我们遇见有序的情况,一定要优先考虑两种算法:

二分和双指针

但是能用双指针,我们优先使用双指针,因为只要能用双指针的算法一般都是最优的,该算法能使时间复杂度降维!

双指针思想:

定义左右两个指针,分情况讨论,循环遍历数组一遍,即可找出答案。

三、原码

cpp 复制代码
int* twoSum(int* price, int priceSize, int target, int* returnSize) {
    //有序,运用双指针的算法解决
    *returnSize = 2;
    int left = 0;
    int right = priceSize - 1;
    while(left < right)
    {
        if((price[left] + price[right]) == target)
        {
            int* arr = (int*)malloc(sizeof(int) * (*returnSize));
            arr[0] = price[left];
            arr[1] = price[right];
            return arr;
        }
        else if(price[left] + price[right] > target)
            right--;
        else
            left++;
    } 
    return NULL;
}
相关推荐
叼烟扛炮1 小时前
C++ 知识点18 内部类
开发语言·c++·算法·内部类
YOGOD有神1 小时前
用AI自动从谷歌地图抓取海外客户,我跑了一次7小时的任务,结果出乎意料
算法
汉克老师1 小时前
GESP5级C++考试语法知识(十五、分治算法(二))
c++·算法·排序算法·分治算法·gesp5级·gesp五级
快瞳科技1 小时前
小样本学习在珍稀鸟类识别中的突破:仅需5张图,让AI认识濒危物种
算法
汉克老师1 小时前
GESP6级C++考试语法知识(五、格雷码)
c++·算法·位运算·异或·gesp6级·gesp六级·格雷码
Ulyanov1 小时前
《从质点到位姿:基于Python与PyVista的导弹制导控制全栈仿真》: 可视化革命——基于 PyVista 的 3D 战场构建与实时渲染
开发语言·python·算法·3d·系统仿真
,,?!,1 小时前
数据结构算法-排序算法
数据结构·算法·排序算法
小白编程锤炼2 小时前
深入解析:质量门禁
人工智能·算法·架构·vibe-coding
‎ദ്ദിᵔ.˛.ᵔ₎2 小时前
C++哈希表
数据结构·c++·散列表
yongui478343 小时前
基于 GA 优化的 BP 神经网络算法分析与 MATLAB 实现
神经网络·算法·matlab