hot100:06三数之和

题目链接:

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

算法思想:

使用双指针的思想,首先需要先对数组进行排序,让数组满足单调性,这样在相加的时候更加方便更新条件;再遍历数组,遍历数组的目的就是确定一个数nums[i],然后在剩下的数中找到两个数时其相加等于-nums[i],这样三个数相加的结果就是0了

注意:

结果要求返回的三元组不能是重复的,所以每找到一组三元组的时候,更新left和right两个指针的时候也需要进行去重(就是多加一个条件,判断更新指针之后的数如果和更新之前的数一样的话就继续更新指针),同时去重的时候也要注意越界问题

java 复制代码
public List<List<Integer>> threeSum(int[] nums) {
        List<List<Integer>> ret = new ArrayList<>();
        //1.先对数组排序
        Arrays.sort(nums);
        //2.使用双指针解决
        //2.1先固定第一个数
        int n = nums.length;
        for(int i = 0;i < n;) {
            //对后面的数组利用双指针的思想
            int target = -nums[i];
            int left = i+1;
            int right = n-1;
            while(left < right) {
                int sum = nums[left] + nums[right];
                if(sum < target) {
                    left++;
                } else if(sum > target) {
                    right--;
                } else {
                    //此时的三元组是:nums[i] nums[left] nums[right]
                    ret.add(new ArrayList<Integer>(Arrays.asList(nums[i],nums[left],nums[right])));
                    left++;
                    right--;
                    //需要去重 去重的时候要防止数组下标越界
                    while(left < right && nums[left] == nums[left-1]) {
                        left++;
                    }
                    while(left < right && nums[right] == nums[right+1]) {
                        right--;
                    }
                }
            }
            //外面固定的数nums[i]也需要进行去重
            i++;
            while(i < n && nums[i] == nums[i-1]) {
                i++;
            }
        }
        return ret;
    }
相关推荐
达达爱吃肉几秒前
openclaw 4.2 飞书出图的bug
java·前端·数据库
灰色小旋风1 分钟前
力扣移除元素C++
数据结构·c++·算法·leetcode
样例过了就是过了4 分钟前
LeetCode热题100 数组中的第K个最大元素
数据结构·c++·算法·leetcode·排序算法
17(无规则自律)6 分钟前
【算法对比】连续子区间的两种控制逻辑:Kadane和滑动窗口
数据结构·c++·算法·动态规划
y = xⁿ8 分钟前
【LeetCodehot100】:贪心算法:T121:买卖股票最佳时机 T55:跳跃游戏 T45:跳跃游戏2
算法·游戏·贪心算法
想不明白的过度思考者9 分钟前
SpringAOP:Java 三大代理模式:从静态代理到 JDK & CGLIB 动态代理
java·开发语言·代理模式
yaoyouzhong10 分钟前
MySQL中DROP、TRUNCATE和DELETE
java
人道领域10 分钟前
【LeetCode刷题日记】:设计链表全解析
算法·leetcode·链表
Meepo_haha11 分钟前
Spring boot 3.3.1 官方文档 中文
java·数据库·spring boot
__土块__13 分钟前
一次 Spring 循环依赖源码走读:从三级缓存误用到 Bean 生命周期深度解析
java·spring·源码分析·aop·bean生命周期·循环依赖·三级缓存