三数之和不会做?暴力解决它!!!

前言

这道题在力扣中是一道中等题,题目见下:

我在这里并不是在刷力扣,因为我只是做题,但并不按照题目要求的时间复杂度来解题。

正文

下面我将详细介绍我关于这题的解法。

我的思路其实很简单,就是想着怎么不费脑子怎么来,这里的"脑子"指的是我的脑子,至于电脑的脑子------时间复杂度出于对我脑子的考虑,我就不考虑它了(狗头)。

初步思路

刚开始我是想着遍历所有可能,然后根据判断语句决定是否输出。事实我也是这么干的,代码放在下面:

ini 复制代码
//双指针法
#include<iostream>
using namespace std;
void main()
{
	int a[] = { -1, 0, 1, 2, -1, -4 };
	int n = sizeof(a) / sizeof(int);
    
	for (int i = 0; i < n - 2; i++)
	{
		for (int j = i + 1; j < n - 1; j++)
		{
			for (int k = j + 1; k < n; k++)
			{
				if (a[i] + a[j] + a[k] == 0)
				{
					cout << "[" << a[i] << "," << a[j] << "," << a[k] << "]" << endl;
					break;
				}
			}
		}
	}
}

在这时,我遇到了一些问题:

可以看到,在运行结果时,三元组出现重复,但是根据题目要求需要消除。所以这种思路是不完善的,后面经过思考,将思路进行完善,最终解决了这个问题。

完善思路

现在的问题就变成了"去重"。

在上一步的运行结果可以看到,第一个三元组和第三个三元组重复,当重复的时候,我们如果将三元组进行排序,那么这两个重复的三元组对应位置的元素就会相等,这样就可以设置条件限制输出从而解决这个问题。

将三元组排序还是有点费脑子,主要是头脑中第一出现的想法就是将原数组进行排序,所以后面也就懒得想了。所以我将原数组进行冒泡升序,然后又定义了一个新数组吧b3用来存放满足条件的三元组。不难知道在进行这样处理后,重复的三元组必定一前一后,也就是说重复的三元组如果要输出的话必定是紧挨着的。所以就先令三元组输出,然后将输出的三元组存放在b3中,在下一次输出前,将要输出的三元组和b3中元素比较,如果一致则限制输出,问题至此也完美的解决了。代码放在下面供参考:

css 复制代码
//双指针法
#include<iostream>
using namespace std;
void main()
{
	int a[] = { -1, 0, 1, 2, -1, -4 };
	int b[3] = { -1 };
	int n = sizeof(a) / sizeof(int);

	for (int i = 0; i < n - 1; i++)
	{
		for(int j=0;j<n-i-1;j++)
			if (a[j] > a[j + 1])
			{
				int temp = a[j];
				a[j] = a[j + 1];
				a[j + 1] = temp;
			}
	}

	for (int i = 0; i < n - 2; i++)
	{
		for (int j = i + 1; j < n - 1; j++)
		{
			for (int k = j + 1; k < n; k++)
			{
				if (a[i] + a[j] + a[k] == 0)
				{
					if (b[0] != a[i] || b[1] != a[j] || b[2] != a[k])
						cout << "[" << a[i] << "," << a[j] << "," << a[k] << "]" << endl;
					b[0] = a[i]; b[1] = a[j]; b[2] = a[k];
					break;
				}
			}
		}
	}
}

运行结果同样贴在下面:

相关推荐
Rust研习社21 分钟前
组合真的优于继承吗?为什么 Rust 和 Go 都拥抱组合舍弃继承?
后端·rust·编程语言
IT_陈寒1 小时前
JavaScript的闭包把我坑惨了,说好的内存会自动回收呢?
前端·人工智能·后端
CaffeinePro1 小时前
Pydantic深度使用:数据校验、枚举、ORM映射
后端·fastapi
Chenyiax2 小时前
从 Chat 到 Responses:OpenAI API 抽象为什么变了?
后端
MariaH2 小时前
Koa和Express的区别
后端
MariaH2 小时前
Koa框架的使用
后端
luckdewei3 小时前
那个用 passlib 做认证的新同事,上线第一天就把用户密码写进了日志
后端
ping某5 小时前
为什么 Nginx 明明监听了 80,转发后端时却用了 4xxxx 端口?
后端·nginx
JustHappy5 小时前
我汇总了身边朋友的经历才发现,其实第一份实习是最难找的......
前端·后端·面试
uhakadotcom5 小时前
在python 的 工程化架构中 ,什么是 薄包装器层?
后端·面试·github