当前位置: 首页 > article >正文

【优选算法】三数之和(双指针算法)

 必须有为成功付出代价的决心,然后想办法付出这个代价。

目录 

一、【题目:15. 三数之和 - 力扣(LeetCode)】

二、【代码原理】

三、【代码】


一、【题目:15. 三数之和 - 力扣(LeetCode)】

需要注意的是,答案中不可以包含重复的三元组,也就是说,满足要求的组与组之间的三个数要不相同,每组要不重复。

二、【代码原理】

解法一:排序+暴力枚举+利用set去重

排序之后用三个for循环枚举出所有的情况一一排查,将满足条件的组都放到set里面去重,再将不同的组返回即可。

解法二:排序+双指针算法

  1. 将数组排序
  2. 先固定一个数 a(从头开始选定)
  3. 在这个数后面的区间内,使用「双指针算法」快速找到两个数之和等于 -a 即可。

同时需要注意的是【去重】操作,这个去重操作,是直接避免结果里有重复的数据

  1. 当处理完一个结果时,left 和 right 指针要跳过两边重复的元素。这样直接避免掉重复的数据。
  2. 当 i+1 == i 时,跳过重复的 i,直到遇到不同的 i。

三、【代码】

class Solution {
public:
    vector<vector<int>> threeSum(vector<int>& nums)
    {
        vector<vector<int>> ret;

        //1.排序
        sort(nums.begin(), nums.end());

        //2.利用双指针解决问题
        int n = nums.size();
        for (int i = 0; i < n; )
        {
            if (nums[i] > 0) break;
            int left = i + 1, right = n - 1, target = -nums[i];
            while (left < right)
            {
                int sum = nums[left] + nums[right];
                if (sum < target) left++;
                else if (sum > target) right--;
                else
                {
                    ret.push_back({ nums[i], nums[left], nums[right] });
                    left++, right--;
                    //去重 left 和 right,用left<right防止越界
                    while (left < right && nums[left] == nums[left - 1])
                        left++;
                    while (left < right && nums[right] == nums[right + 1])
                        right--;
                }
            }
            i++;
            //去重i,用i<n 来防止越界
            while (i < n && nums[i] == nums[i - 1]) i++;
        }
        return ret;
    }
};

代码一定要思考透彻,多回顾,不要怕动脑,多思考几遍就没有想象中的那么复杂了,

明天继续。。。


http://www.kler.cn/a/506092.html

相关文章:

  • C#上位机通过CAN总线发送bin文件
  • Yolov8 目标检测剪枝学习记录
  • Linux浅谈——管道、网络配置和客户端软件的使用
  • 告别 Excel,拥抱 R 语言:开启数据分析新时代
  • 数据结构与算--堆实现线段树
  • 【学习笔记】理解深度学习的基础:机器学习
  • 【云岚到家】-day02-客户管理-认证授权
  • 如何在vue中渲染markdown内容?
  • 如何清理docker垃圾
  • Spring boot面试题----Spring Boot如何实现应用程序的热部署
  • 蓝桥杯备考:二叉树详解
  • STL中的List
  • 机器学习(一)
  • 基础vue3前端登陆注册界面以及主页面设计
  • centos 7 NFS部署
  • 计算机网络的五层协议
  • 【EI 会议征稿通知】第七届机器人与智能制造技术国际会议 (ISRIMT 2025)
  • Springboot Redisson 分布式锁、缓存、消息队列、布隆过滤器
  • KVM创建ubuntu20.04虚机,部署K8S,再克隆出二份,做为Worker节点加入集群,通过Helm创建2个Pod,让它们之间通过域名互访
  • 解锁转型密码:不同方向的技能与素质修炼手册
  • PHP与HTML、CSS、JavaScript、jQuery的关系**
  • 主动出击,在去中心化世界中成为连接中心
  • 线性变换与矩阵的关系及其在机器学习中的应用
  • GoLang教程004:流程控制和if语句介绍
  • 微信小程序在使用页面栈保存页面信息时,如何避免数据丢失?
  • C#局部函数 VS Lambda表达式