三数之和

题目

给你一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?请你找出所有和为 0 且不重复的三元组。

注意:答案中不可以包含重复的三元组。

示例 1:

输入:nums = [-1,0,1,2,-1,-4]
输出:[[-1,-1,2],[-1,0,1]]

示例 2:

输入:nums = []
输出:[]

示例 3:

输入:nums = [0]
输出:[]

提示:

  • 0 <= nums.length <= 3000
  • -105 <= nums[i] <= 105

Related Topics

数组

双指针

排序


解题思路


代码实现

class Solution {
    public static List<List<Integer>> threeSum(int[] nums) {
//        1、创建ans记录符合三数之和结果集
        List<List<Integer>> ans = new ArrayList<>();
//        2、排除特殊情况
        int length = nums.length;
        if (nums == null || length < 3) return -1;
//        3、普通情况的处理
//        3.1、先排序
        Arrays.sort(nums);
//        3.2、确定一个nums[i]值,在该值右侧进行取值验算是否符合三数之和
        for (int i = 0; i < length; i++) {
//            nums[i]若大于0,则排序后右侧值与其相加必大于0
            if (nums[i] > 0) break;
//            去重
            if (i > 0 && nums[i] == nums[i - 1]) continue;
//            标记左右侧值
            int L = i + 1;
            int R = length - 1;
//            找出符合三数之和的结果集
            while (L < R) {
//             标记三数之和
                int sum = nums[i] + nums[L] + nums[R];
//                若符合条件,添加至结果集中
                if (sum = 0) {
                    ans.add(Arrays.asList(nums[i],nums[L],nums[R]));
//                    去重
                    while (L < R && nums[L] == nums[L + 1]) L++;
                    while (L < R && nums[R] == nums[R - 1]) R--;
                    L++;
                    R--;
                }
                else if (sum < 0) L++;
                else if (sum > 0) R--
            }
        }
        return ans;
    }
}
posted @ 2021-11-03 09:45  软件工程师蜗小牛  阅读(28)  评论(0)    收藏  举报