寒假打卡:2026-01-24

日常学习:

购物车内的商品价格按照升序记录于数组 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]

思路:
解法1(暴力算法):固定第一个数,依次循环后面的数,直至和为target

伪代码:

for(i=0;i<n;i++)

for(j=i+1;j<n;j++)

check(price[i]+price[j]==target)

解法2(双指针算法):利用单调性,使用双指针算法(left,right),直至sum(price[left]+price[right])为target

情况1:sum>target:right--

情况2:sum<target:left++

情况3:sum=target:return price[left],price[right]

伪代码:

int left=0,right=price.length-1;

while(left<right){

int sum=price[left]+price[right];

if(sum>target) right--;

else if(sum<target) left++;

else return new int[] {price[left],price[right]};

}

return new int[]{0};

相关推荐
亲爱的非洲野猪2 小时前
动态规划进阶:多维DP深度解析
算法·动态规划
AlenTech2 小时前
197. 上升的温度 - 力扣(LeetCode)
算法·leetcode·职场和发展
橘颂TA3 小时前
【Linux 网络】TCP 拥塞控制与异常处理:从原理到实践的深度剖析
linux·运维·网络·tcp/ip·算法·职场和发展·结构与算法
tobias.b4 小时前
408真题解析-2010-9-数据结构-折半查找的比较次数
java·数据结构·算法·计算机考研·408真题解析
源代码•宸4 小时前
Leetcode—404. 左叶子之和【简单】
经验分享·后端·算法·leetcode·职场和发展·golang·dfs
WBluuue4 小时前
数据结构与算法:dp优化——优化尝试和状态设计
c++·算法·leetcode·动态规划
im_AMBER4 小时前
Leetcode 105 K 个一组翻转链表
数据结构·学习·算法·leetcode·链表
sin_hielo4 小时前
leetcode 1877
数据结构·算法·leetcode
睡不醒的kun4 小时前
定长滑动窗口-基础篇(2)
数据结构·c++·算法·leetcode·职场和发展·滑动窗口·定长滑动窗口