LeetCode Hot100 15.三数之和

题目描述

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

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

15. 三数之和 - 力扣(LeetCode)

思路

首先对nums排序,每次先固定一个nums[i],然后在i后面的部分使用双指针l和r进行搜索,如果nums[i]+nums[l]+nums[r]<0,那么l右移,否则r左移

需要保证i,l,r都被去重过,所以在每次迭代一个新的i时,跟之前处理过的nums[i-1]对比,如果相等那么跳过此次迭代;每次找到一个满足条件的i,l,r时,对l和r去重,跟还未处理过的nums[l+1],nums[r-1]对比,相同则跳过。

代码

html 复制代码
class Solution {
    public List<List<Integer>> threeSum(int[] nums) {
        List<List<Integer>> ans = new ArrayList<>();
        Arrays.sort(nums);
        for(int i = 0; i < nums.length-2; i++){
            if(i>0&&nums[i]==nums[i-1]) continue;
            int l=i+1,r=nums.length-1;
            while(l<r){
                if(nums[l]+nums[r]==-nums[i]){
                    ans.add(List.of(nums[l],nums[r],nums[i]));
                    while(l<r&&nums[l]==nums[l+1]) l++;
                    while(l<r&&nums[r]==nums[r-1]) r--;
                    l++;
                    r--;
                }
                else if(nums[l]+nums[r]<-nums[i]){
                    l++;
                }
                else{
                    r--;
                }
            }
        }
        return ans;
    }
}
相关推荐
一条大祥脚8 小时前
Codeforces Round 1099 (Div. 2) 构造|贪心|图论|还原数组
java·算法·图论
huaCodeA8 小时前
Android面试-Flow相关
android·面试·职场和发展
JAVA社区8 小时前
Java进阶全套教程(三)—— Spring框架核心精讲
java·开发语言·spring·面试·职场和发展·mybatis
Sheldon Chao8 小时前
Lecture 7 基于策略梯度的算法
人工智能·算法·机器学习
始三角龙9 小时前
LeetCode hoot 100 -- 缺失的第一个正整数
算法·leetcode·职场和发展
飞Link9 小时前
深度解析孪生网络(Siamese Network):从原理、技巧到实战应用
算法·数据挖掘·回归
测试狗科研平台9 小时前
洞悉微观电荷流动,VASP计算电荷密度分布
算法·云计算·开源软件
fqq39 小时前
java基础面试题目
面试·职场和发展
Orz_Sponge_Bob9 小时前
温州市第三届青少年程序设计竞赛(小学组)题解
算法
小江的记录本9 小时前
【Java并发编程】锁机制:volatile:JMM内存模型、可见性/禁止指令重排、内存屏障、单例模式中的应用(附《思维导图》+《面试高频考点清单》)
java·后端·python·mysql·单例模式·面试·职场和发展