算法每日一题 Day08|双指针法解决三数之和

文章目录

一、题目描述

题目链接:https://leetcode.cn/problems/3sum/description/


二、解题思路

这道题的核心在于:去重和边界值的处理

具体思路如下:

  • 第一步:先对数组进行排序,让数组从小到大有序
  • 第二步:固定一个数,然后在剩下的区间内,进行两数之和的求解
  • 第三步:两数之和的解要和固定的数的值为相反数,这样相加才为0
  • 第四步:去重,对重复的元素组合去重
  • 第五步:处理好边界情况。

三、关键点 / 易错点

  • 边界情况:要考虑到left,right,和i的边界情况,防止索引越界
  • 容易出错的地方:不仅仅要对固定的数进行去重,还需要对left指针和right指针指向的元素进行去重
  • 可以优化的点:当固定的数大于0时,就可以不用继续判断,直接跳出循环。

四、代码实现(Java)

java 复制代码
class Solution {
    public List<List<Integer>> threeSum(int[] nums) {
        List<List<Integer>> result = new ArrayList<>();
        int n = nums.length;
        // 1.对数组进行排序
        Arrays.sort(nums);
        //注意这里for循环里面的i++可以不要了,后面写了++,以免跳过不重复的数,漏写
        for (int i = 0; i < n;) {
            int left = i + 1;
            int right = n - 1;
            //目标值
            int target = -nums[i];
            while (left < right) {
                //求区间内两数之和
                int sum = nums[left] + nums[right];
                if (sum > target) {
                    right--;
                } else if (sum < target) {
                    left++;
                } else {
                    //target == sum
                    List<Integer> list = new ArrayList<>();
                    list.add(nums[left]);
                    list.add(nums[right]);
                    list.add(nums[i]);
                    result.add(list);
                    //缩小区间
                    left++;
                    right--;
                    //left和 right指向的元素去重 并保证不越界
                    while (left < right && nums[left] == nums[left - 1])
                        left++;
                    while (left < right && nums[right] == nums[right + 1])
                        right--;

                }
            }
            // 对i指向的固定元素去重 保证不越界
            i++;
            while (i < n && nums[i] == nums[i - 1])
                i++;

        }
        return result;
    }
}

五、总结

要处理好边界情况和去重操作需要多看看。

相关推荐
勤自省7 分钟前
吴恩达机器学习课程实验:线性回归模型入门(课后实验)
人工智能·算法·机器学习·回归·线性回归
ChillCoding12 分钟前
更新中:C++ STL库,查找排序(基础算法),数据结构,数学算法,竞赛相关基础
数据结构·c++·算法
智者知已应修善业17 分钟前
【51单片机使用IO组赋值方法实现无源蜂鸣器响时LED12亮不响时34亮】2024-3-7
c++·经验分享·笔记·算法·51单片机
珊瑚里的鱼27 分钟前
【动态规划】按摩师
算法·动态规划
Fms_Sa27 分钟前
贪心算法-背包问题
算法·贪心算法·c#
大雨淅淅34 分钟前
【机器人】ROS2 机械臂控制(MoveIt2)从入门到实战
人工智能·python·神经网络·学习·算法·机器学习·机器人
智者知已应修善业1 小时前
【51单片机0.1秒计时到21.0时点亮LED】2024-1-5
c++·经验分享·笔记·算法·51单片机
apcipot_rain1 小时前
计科八股20260606——二叉树、PCA、图深度学习、进程上下文、C语言预编译、文件读写、单精度浮点数
c语言·数据结构·算法·pca·图神经网络
scx_link1 小时前
逻辑回归的总结
算法·机器学习·逻辑回归
沐籽李1 小时前
Proteina-Complexa:NVIDIA 如何把蛋白 Binder 设计推进到全原子生成时代?
大数据·人工智能·算法·英伟达·蛋白质生成