三数之和问题

题目描述

给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != j、i != k 且 j != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请你返回所有和为 0 且不重复的三元组。

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

示例

思路

这个必须先排序,然后三数之和问题我们可以参考两数之和,我们先确定一个数,比如说先确定nums[i],那么问题就转换为两数之和等于target-nums[i],此处的target是0而已。

代码如下

java 复制代码
public List<List<Integer>> threeSum(int[] nums) {
        int len = nums.length;
        Arrays.sort(nums);
        List<List<Integer>> res = new ArrayList<>();
        for(int i = 0;i < len - 2;i++){
            // 去重操作
            if(i > 0 && nums[i] == nums[i-1]) continue;
            // 当前三个数相加大于0,直接退出
            if(nums[i] + nums[i+1] + nums[i+2] > 0) break;
            // 当前数加上后两个数小于0,那么当前坐标后移。
            if(nums[i] + nums[len-2] + nums[len-1] < 0) continue;
            int j = i + 1;
            int k = len - 1;
            // 确定nums[i]
            while(j < k){
                int sum = nums[i] + nums[j] + nums[k];
                if(sum < 0){
                    j++;
                }else if(sum > 0){
                    k--;
                }else{
                    List<Integer> list = new ArrayList<>();
                    list.add(nums[i]);
                    list.add(nums[j]);
                    list.add(nums[k]);
                    res.add(list);
                    j += 1;
                    // 去重操作
                    while(j < k && nums[j] == nums[j-1]){
                        j++;
                    }
                    k -= 1;
                    // 去重操作
                    while(j < k && nums[k] == nums[k+1]){
                        k--;
                    }
                }
            }

        }
        return res;
    }
相关推荐
MediaTea2 小时前
AI 术语通俗词典:C4.5 算法
人工智能·算法
Navigator_Z2 小时前
LeetCode //C - 1033. Moving Stones Until Consecutive
c语言·算法·leetcode
WBluuue2 小时前
数据结构与算法:莫队(一):普通莫队与带修莫队
c++·算法
风筝在晴天搁浅2 小时前
n个六面的骰子,扔一次之后和为k的概率是多少?
算法
MATLAB代码顾问4 小时前
Python实现蜂群算法优化TSP问题
开发语言·python·算法
代码飞天4 小时前
机器学习算法和函数整理——助力快速查阅
人工智能·算法·机器学习
jiushiapwojdap4 小时前
LU分解法求解线性方程组Matlab实现
数据结构·其他·算法·matlab
笨笨饿4 小时前
69_如何给自己手搓一个串口
linux·c语言·网络·单片机·嵌入式硬件·算法·个人开发
纽扣6675 小时前
【算法进阶之路】链表进阶:删除、合并、回文与排序全解析
数据结构·算法·链表
消失的旧时光-19435 小时前
统一并发模型:线程、Reactor、协程本质是一件事(从线程到协程 · 第6篇·终章)
java·python·算法