[Java][Leetcode middle] 15. 三数之和

固定一个数i,然后寻找其中的两个数。

  • 为什么要先排序:排序之后才可以更好的去重,例如如果答案会是[-1, 0, 1] 排序之后返回的结果天然就是有序的,不需要额外区分。i就是-1,left从0开始,避免了重复的问题;
  • 为什么遇到跟上一个数相同的要跳过:例如[-1, -1, -1, 0, 1],此时无论用哪一个-1结果都是相同的,因此用最后一个。
  • 为什么 sum为0时,要L++,R--:因为sum=0时,说明找到了一个符合条件的数,二者同时移动去找下一组合适的解(只移动一边的话,只会导致sum大于0或者小于0,永远不会等于0,无意义)。
java 复制代码
class Solution {
    public List<List<Integer>> threeSum(int[] nums) {
        // 排序
         Arrays.sort(nums);
         List<List<Integer>> res = new ArrayList<>();
         int len = nums.length;
         
         for(int i = 0;i<len;i++){
             if(i > 0 && nums[i] == nums[i-1]) continue;

             int left = i+1;
             int right = len - 1;
             while(left < right){
                int sum = nums[i] + nums[left] + nums[right];
                if(sum == 0){
                    res.add(Arrays.asList(nums[i], nums[left], nums[right]));

                    while(left < right && nums[left] == nums[left + 1]){
                        left++;
                    }
                    while(left < right && nums[right] == nums[right - 1]){
                        right-- ;
                    }

                    left++;
                    right--;
                }else if(sum > 0){
                    right--;
                }else{
                     left++;
                }
             }

         }

         return res;
    }
}
相关推荐
Mahir087 小时前
Spring 循环依赖深度解密:从问题本质到三级缓存源码级解析
java·后端·spring·缓存·面试·循环依赖·三级缓存
RyFit8 小时前
SpringAI 常见问题及解决方案大全
java·ai
石山代码9 小时前
C++ 内存分区 堆区
java·开发语言·c++
心中有国也有家9 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
绝知此事9 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
无风听海9 小时前
C# 隐式转换深度解析
java·开发语言·c#
碧海银沙音频科技研究院9 小时前
通话AEC与语音识别AEC的软硬回采链路
深度学习·算法·语音识别
一只大袋鼠10 小时前
Git 进阶(二):分支管理、暂存栈、远程仓库与多人协作
java·开发语言·git
csdn_aspnet10 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展