力扣hot100 三数之和 双指针 细节去重

Problem: 15. 三数之和

文章目录

思路

👨‍🏫 参考

Code

⏰ 时间复杂度: O ( n 2 ) O(n^2) O(n2)

🌎 空间复杂度: O ( 1 ) O(1) O(1)

Java 复制代码
class Solution {
 	public List<List<Integer>> threeSum(int[] nums)
	{
		List<List<Integer>> res = new ArrayList<>();
		int len = nums.length;
		if (len < 3)
			return res;
		Arrays.sort(nums);// 升序排序

		for (int i = 0; i < len; i++)// i选一个数(三个数中最小的数)
		{
			if (nums[i] > 0)// 最小数已经 > 0,和不可能 == 0
				break;
			// 当前数和前一个数相同,去重
			if (i > 0 && nums[i] == nums[i - 1])
				continue;

			int l = i + 1;// 选取第二个数(中间的数)
			int r = len - 1;// 选取第三个数(最大的数)
			while (l < r)
			{
				int sum = nums[i] + nums[l] + nums[r];
				if (sum == 0)
				{
					res.add(Arrays.asList(nums[i], nums[l], nums[r]));
//					 去重 l 和 r 的数
//					跳过重复的值,避免重复解
//					例:[0,-2,-2,-1,1,2,2]  中的 -2 -2 2 2 就需要去重
					while (l < r && nums[l] == nums[l + 1])
						l++;
					while (l < r && nums[r] == nums[r - 1])
						r--;
//					走到这,l 是连续相同段的最后一个,r 是连续相同段的第一个
//					再跳一次,把 nums[l] nums[r] 跳过
					l++;
					r--;
				} else if (sum < 0)// 左边的值 调大一点
					l++;
				else if (sum > 0)// 右边的值 调小一点
					r--;
			}
		}
		return res;
	}
}
相关推荐
Java后端的Ai之路1 小时前
Text-to-SQL与智能问数完全指南:基本概念、核心原理、Python实战教学及企业项目落地
数据库·python·sql·text-to-sql·智能问数
2301_782659181 小时前
如何使用Navicat连接云端MariaDB_白名单与实例配置
jvm·数据库·python
2301_803875617 小时前
PHP 中处理会话数组时的类型错误解析与修复指南
jvm·数据库·python
m0_743623927 小时前
c++如何批量修改文件后缀名_std--filesystem--replace_extension【实战】
jvm·数据库·python
三毛的二哥7 小时前
BEV:典型BEV算法总结
人工智能·算法·计算机视觉·3d
2501_914245938 小时前
CSS如何处理CSS变量作用域冲突_利用特定类名重写变量值
jvm·数据库·python
菜鸟学Python8 小时前
Python生态在悄悄改变:FastAPI全面反超,Django和Flask还行吗?
开发语言·python·django·flask·fastapi
南宫萧幕8 小时前
自控PID+MATLAB仿真+混动P0/P1/P2/P3/P4构型
算法·机器学习·matlab·simulink·控制·pid
<-->8 小时前
Megatron(全称 Megatron-LM,由 NVIDIA 开发)和 DeepSpeed(由 Microsoft 开发)
人工智能·pytorch·python·深度学习·transformer
测试19989 小时前
2026最新软件测试面试八股文【附文档】
自动化测试·软件测试·python·测试工具·面试·职场和发展·测试用例