【优选算法】查找总价格为目标值的两个商品(双指针)

算法_云边有个稻草人的博客-CSDN博客

目录

解法一:暴力算法

解法二:双指针(时间复杂度为O(N))

【代码编写】


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

解法一:暴力算法

用两个for循环,列出所有的两个数的和进行判断,时间复杂度为O(N^2),不推荐。

算法流程:
两层 for 循环
外层 for 循环依次枚举第⼀个数 a ;
内层 for 循环依次枚举第⼆个数 b ,让它与 a 匹配;
ps :这⾥有个魔⻤细节:我们挑选第⼆个数的时候,可以不从第⼀个数开始选,因为 a 前⾯的数我们都已经在之前考虑过了;因此,我们可以从 a 往后的数开始列举。 然后将挑选的两个数相加,判断是否符合⽬标值。

cpp 复制代码
class Solution 
{
public:
	vector<int> twoSum(vector<int>& nums, int target) 
	{
		int n = nums.size();
		for (int i = 0; i < n; i++) 
		{ // 第⼀层循环从前往后列举第⼀个数
			for (int j = i + 1; j < n; j++) 
			{ // 第⼆层循环从 i 位置之后列举第⼆个数
					if (nums[i] + nums[j] == target) // 两个数的和等于⽬标值,说明我们已经找到结果了
						return { nums[i], nums[j] };
			}
		}
		return { -1, -1 };
	}
};

解法二:双指针(时间复杂度为O(N))

【代码编写】

cpp 复制代码
class Solution 
{
public:
    vector<int> twoSum(vector<int>& price, int target) 
    {
        int left = 0;
        int right = price.size()-1;
        while(left<right)
        {
            int sum = price[left]+price[right];
            if(sum > target)
                right--;
            else if(sum < target)
                left++;
            else 
                return {price[left],price[right]};
        }
        //这里对于编译器,若没有值等于target要设置一个返回值,让所有的情况都有所返回
        return {-1,-1};
    }
};

完------

继续。。。

相关推荐
Zedthm1 分钟前
LeetCode1004. 最大连续1的个数 III
java·算法·leetcode
神的孩子都在歌唱21 分钟前
3423. 循环数组中相邻元素的最大差值 — day97
java·数据结构·算法
YuTaoShao26 分钟前
【LeetCode 热题 100】73. 矩阵置零——(解法一)空间复杂度 O(M + N)
算法·leetcode·矩阵
dying_man1 小时前
LeetCode--42.接雨水
算法·leetcode
vortex52 小时前
算法设计与分析 知识总结
算法
艾莉丝努力练剑2 小时前
【C语言】学习过程教训与经验杂谈:思想准备、知识回顾(三)
c语言·开发语言·数据结构·学习·算法
ZZZS05162 小时前
stack栈练习
c++·笔记·学习·算法·动态规划
hans汉斯3 小时前
【人工智能与机器人研究】基于力传感器坐标系预标定的重力补偿算法
人工智能·算法·机器人·信号处理·深度神经网络
vortex54 小时前
算法设计与分析:分治、动态规划与贪心算法的异同与选择
算法·贪心算法·动态规划
前端拿破轮5 小时前
🤡🤡🤡面试官:就你这还每天刷leetcode?连四数相加和四数之和都分不清!
算法·leetcode·面试