LeetCode--15. 三数之和
最后更新于
最后更新于
给你一个整数数组
nums
,判断是否存在三元组[nums[i], nums[j], nums[k]]
满足i != j
、i != k
且j != k
,同时还满足nums[i] + nums[j] + nums[k] == 0
。请你返回所有和为0
且不重复的三元组。**注意:**答案中不可以包含重复的三元组。
三数之和,总体思路是排序+双指针,相较于暴力的O(n^3)优化了不少,遍历过程中也可以适当的剪枝来进一步优化,
具体思路如下:
先排序,将数组变成有序的,数组长度为n
随后第一层遍历元素i
定义双指针:j,k以及目标值target,其中,j的初始值为i + 1, k的初始值为n - 1, target为-nums[i].
循环遍历j,循环内嵌k,当nums[k] + nums[j] > target时,k--,最后如果找不到相应的target,则进行continue,若找到了,则加入答案中。
在遍历过程中,如果nums[i] > 0时,可以直接返回答案。
具体代码如下: