[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;
    }
}
相关推荐
图码4 小时前
矩阵数据结构入门指南:声明、初始化与基本操作
运维·数据结构·线性代数·算法·矩阵
苍煜4 小时前
Java自定义注解-SpringBoot实战
java·开发语言·spring boot
XS0301064 小时前
Java ArrayList
java·开发语言
凯尔萨厮4 小时前
Springboot2.x+JSP项目创建
java·数据库
Navigator_Z4 小时前
LeetCode //C - 1030. Matrix Cells in Distance Order
c语言·算法·leetcode
钝挫力PROGRAMER4 小时前
贫血模型的改进
java·开发语言·设计模式·架构
无敌昊哥战神4 小时前
【回溯算法巅峰之作】LeetCode 51. N皇后问题详解与常见避坑指南 (C/C++/Python)
c语言·算法·leetcode
小书房4 小时前
Kotlin的内联函数
java·开发语言·kotlin·inline·内联函数
mftang4 小时前
BSS段、Data段、Text段的具体含义和数据特性
数据库·算法