LeetCode Hot100 15.三数之和

题干:

思路:

首先想到的是哈希表,类似于两数之和的想法,共两层循环,将遍历到的第一个元素和第二个元素存入哈希表中,然后按条件找第三个元素,但是这道题有去重的要求,哈希表实现较为麻烦。

优解是用双指针的解法,将数组排序,排序的目的是为了后续定义的判定条件,题干要求返回的是数组中的值,并不是索引所以可以排序。排完序,先固定第一个元素,然后固定左指针和右指针

​​​​​​​ ​​​​​​​

当三个元素和大于0时,需要将右指针左移,元素和小于0时,将左指针右移。另外还要考虑去重。

代码实现如下:

java 复制代码
class Solution {
    public List<List<Integer>> threeSum(int[] nums) {
        List<List<Integer>> res = new ArrayList<>();
        //对数组进行排序
        Arrays.sort(nums);

        for (int i = 0; i < nums.length; i++) {
            //如果第一个数字已经大于0,则凑不成三元组
            if(nums[i] > 0){
                return res;
            }
            //对第一个数字去重
            if(i > 0 && nums[i] == nums[i-1]){
                continue;
            }

            //记录第一个数字
            int temp = nums[i];
            //定义双指针
            int left = i + 1;
            int right = nums.length - 1;
            while(right > left){
                int sum = temp + nums[left] + nums[right];
                if(sum > 0){
                    right--;
                }else if(sum < 0){
                    left++;
                }else {
                    //Arrays.asList():将数组转换为一个固定的列表
                    res.add(Arrays.asList(temp, nums[left], nums[right]));
                    //对第二个和第三个数数字去重
                    while(right > left && nums[right] == nums[right-1]){
                        right--;
                    }
                    while(left < right && nums[left] == nums[left + 1]){
                        left++;
                    }
                    right--;
                    left++;
                }
            }

        }

        return res;
        
    }
}
相关推荐
逆境不可逃5 分钟前
LeetCode 热题 100 之 394. 字符串解码 739. 每日温度 84. 柱状图中的最大矩形
算法·leetcode·职场和发展
重生之后端学习18 分钟前
62. 不同路径
开发语言·数据结构·算法·leetcode·职场和发展·深度优先
小资同学20 分钟前
考研机试 -Kruskal算法
算法
y芋泥啵啵gfe23 分钟前
AI考研深造VS直接工作:选对赛道,认证为竞争力加码
人工智能·职场和发展
big_rabbit050223 分钟前
[算法][力扣283]Move Zeros
算法·leetcode·职场和发展
小资同学25 分钟前
考研机试动态规划 线性DP
算法·动态规划
listhi52031 分钟前
两台三相逆变器并联功率分配控制MATLAB实现
算法
Evand J34 分钟前
【IMM】非线性目标跟踪算法与MATLAB实现:基于粒子滤波的交互式多模型,结合CV和CT双模型对三维空间中的机动目标进行高精度跟踪
算法·matlab·目标跟踪·pf·粒子滤波·imm·多模型
重生之后端学习35 分钟前
64. 最小路径和
数据结构·算法·leetcode·排序算法·深度优先·图论
We་ct1 小时前
LeetCode 212. 单词搜索 II:Trie+DFS 高效解法
开发语言·算法·leetcode·typescript·深度优先·图搜索算法·图搜索