当前位置: 首页 > news >正文

双数之和+三数之和+四数之和

1.题目分析

2.算法原理

我们只需要利用双指针算法就可以计算排序之后的双数之和。排序用库中自带的sort函数。双指针算法利用下标访问。用int和下标访问代替指针更为直观。还需要考虑去重的操作。即left++之后,nums[left]==nums[left-1]还需要left++;

3.代码实操

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

1.题目分析

2.算法原理

三数之和先固定第一个数字,然后target-固定的数字取相反数等于两数之和即可,需要注意去重操作和双数之和类似。

3.代码实操

class Solution {
public:
    vector<vector<int>> threeSum(vector<int>& nums) {
        sort(nums.begin(), nums.end());
size_t left = 1;
int right = nums.size() - 1;
size_t cur = 0;
int count = 0;
vector<vector<int>>num;
vector<int>arr;
while (cur != nums.size() - 2)
{
	while (left < right)
	{
		if (nums[left] + nums[right] == -nums[cur])
		{
			arr.push_back(nums[left]);
			arr.push_back(nums[right]);
			arr.push_back(nums[cur]);
			num.push_back(arr);
			arr.clear();
			 count = 0;
			while (nums[left] == nums[left + 1])
			{
				if (left + 1 < nums.size() )
					left++;
				if (left + 1 == nums.size())
					break;
			}
			if (left + 1 < nums.size() )
				left++;
			else
				break;
			while (nums[right] == nums[right - 1])
			{
				if (right - 1 > -1)
				right--;
				if (right - 1 == -1)
					break;
			}
			if (right - 1 > -1)
				right--;
			else
				break;
		}
		else
		{
			if (nums[left] + nums[right] < -nums[cur])
			{
				if (left + 1 < nums.size() )
				left++;
			}
			else {
				if (right - 1 > -1)
				right--;
			}
		}
	}
	while (nums[cur] == nums[cur + 1])
	{
		if(cur+1<nums.size())
		cur++;
		if (cur == nums.size() - 2)
			break;
	}
	if (cur == nums.size() - 2)
		break;
	if (cur + 1 < nums.size())
		cur++;
	else
		break;
	right = nums.size() - 1;
	left = cur + 1;
}
return num;
    }
};

1.题目分析

2.算法原理

四数之和用三数之和和双数之和。依次固定第一个数字第二个数字,然后用双数之和。它们的操作都是类似的。区别在于这一个题目用前一个题目的思路。为了避免数字相同超出边界要做边界判断。

注意:去重操作和不漏操作。

去重在于++之后看是否和前一个值相等,是则再次++否则结束循环。

不漏操作时找出双数之和和三数之和后还要继续该循环,找出所以得双数之和和三数之和的符合值。

3.代码实操

class Solution {
public:
vector<vector<int>> fourSum(vector<int>& nums, int target) {
    	vector<int>a;
	vector<vector<int>>num;
        if(nums.size()<4) return num;
	sort(nums.begin(), nums.end());
	int cur = 0;
	int pos = 1;
	int left = pos + 1;
	int right = nums.size() - 1;
	int sum = 0;
	while (cur < nums.size() - 3)
	{
		long long int target1 = target - nums[cur];
		while (pos < nums.size() - 2)
		{
			long long int target2 = target1 - nums[pos];
			while (left < right)
			{
				sum = nums[left] + nums[right];
				if (sum < target2)
				{
					left++;
				}
				if (sum > target2)
				{
					right--;
				}
				if (sum == target2)
				{
					a.push_back(nums[cur]);
					a.push_back(nums[pos]);
					a.push_back(nums[left]);
					a.push_back(nums[right]);
					num.push_back(a);
					a.clear();
					left++;
					right--;
					while (left < right&&nums[left - 1] == nums[left])
					{
						left++;
					}
					while (left < right&&nums[right + 1] == nums[right])
					{
						right--;
					}
				}
			}
			pos++;
			while (pos<nums.size()-2&&nums[pos - 1] == nums[pos])
			{
				pos++;
				if (pos >= nums.size() - 2)break;
			}
			if (pos >= nums.size() - 2)break;
			left = pos + 1;
			right = nums.size() - 1;
		}
		cur++;
		while (nums[cur - 1] == nums[cur])
		{
			cur++;
			if (cur >= nums.size() - 3)break;
		}
		if (cur >= nums.size() - 3)return num;
		pos = cur + 1;
		left = pos + 1;
		right = nums.size() - 1;
	}
	return num;
}
};

相关文章:

  • CyclicBarrier 基本用法
  • 【JS进阶】对象解构与数组解构
  • 基于3A4000及CentOS的银河麒麟V10离线源码编译安装VLC
  • Java八股文背诵 第四天JVM
  • BC3 有容乃大(sizeof关键字,sizeof(long long) >= sizeof(long) >= sizeof(int)
  • Spring 中的 @Cacheable 缓存注解
  • Hook_Unfinished
  • 【含文档+PPT+源码】基于微信小程序的学校体育馆操场预约系统的设计与实现
  • python的web框架flask(hello,world版)
  • 【读者求助】如何跨行业进入招聘岗位?
  • 并发编程--互斥锁与读写锁
  • Linux基础1
  • Linux 入门八:Linux 多进程
  • JavaScript 简单类型与复杂类型-简单类型传参
  • 多模态大语言模型arxiv论文略读(十四)
  • qt上设置 WebAssembly显示中文
  • 『生成内容溯源系统』详解
  • java之file和IO流
  • 关于编译原理——递归下降分析器的设计
  • 用 NextJS写一个 Rock Paper Scissors 小游戏(附在线试玩地址)
  • 影视传媒公司网站php源码/谷歌seo零基础教程
  • 哪些网站可以做易拉宝/免费制作网站平台
  • 流行的企业网站推广/网站优化师
  • 网站页脚需要放什么/百度指数如何提升
  • 网站建设中最重要的/百度长尾关键词挖掘工具
  • 四川成都疫情最新动态/厦门站长优化工具