力扣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;
	}
}
相关推荐
有意义14 小时前
深度拆解分割等和子集:一维DP数组与倒序遍历的本质
前端·算法·面试
xlp666hub15 小时前
Leetcode第二题:用 C++ 解决字母异位词分组
c++·leetcode
用户7268761033716 小时前
解放双手的健身助手:基于 Rokid AR 眼镜的运动计时应用
算法
Wect16 小时前
LeetCode 17. 电话号码的字母组合:回溯算法入门实战
前端·算法·typescript
明月_清风18 小时前
Python 装饰器前传:如果不懂“闭包”,你只是在复刻代码
后端·python
明月_清风18 小时前
打破“死亡环联”:深挖 Python 分代回收与垃圾回收(GC)机制
后端·python
xlp666hub1 天前
Leetcode第一题:用C++解决两数之和问题
c++·leetcode
ZhengEnCi1 天前
08c. 检索算法与策略-混合检索
后端·python·算法
程序员小崔日记1 天前
大三备战考研 + 找实习:我整理了 20 道必会的时间复杂度题(建议收藏)
算法·408·计算机考研
lizhongxuan2 天前
AI小镇 - 涌现
算法·架构