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

前言

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

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

正文

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

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

初步思路

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

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;
				}
			}
		}
	}
}

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

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

完善思路

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

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

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

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;
				}
			}
		}
	}
}

运行结果同样贴在下面:

相关推荐
轩辰~7 分钟前
网络协议入门
linux·服务器·开发语言·网络·arm开发·c++·网络协议
小_太_阳16 分钟前
Scala_【1】概述
开发语言·后端·scala·intellij-idea
智慧老师25 分钟前
Spring基础分析13-Spring Security框架
java·后端·spring
lxyzcm27 分钟前
C++23新特性解析:[[assume]]属性
java·c++·spring boot·c++23
蜀黍@猿1 小时前
C/C++基础错题归纳
c++
雨中rain1 小时前
Linux -- 从抢票逻辑理解线程互斥
linux·运维·c++
搬码后生仔2 小时前
asp.net core webapi项目中 在生产环境中 进不去swagger
chrome·后端·asp.net
凡人的AI工具箱2 小时前
每天40分玩转Django:Django国际化
数据库·人工智能·后端·python·django·sqlite
ALISHENGYA2 小时前
全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之分支结构(实战项目二)
数据结构·c++·算法
arong_xu2 小时前
现代C++锁介绍
c++·多线程·mutex