leetcode15.三数之和题解:逻辑清晰带你分析

介绍


题源

分析

1.双指针+固定一个数

首先明白一点,我们有三个数,我们想使用双指针,那就必须固定一个数。

2.二分

本题还涉及二分,双指针经常和二分结合使用(二分本质就是双指针,仔细思考这思考这句话),所以我们要在一开始先排序。

3.去重

题目要求答案不可包含重复的三元组,那么就必须考虑去重。

又分两种情况:

1.对固定的数来说,用当前数和前一个数比较,相同直接跳过本次了。

2.对后两个数,只需要考虑当双指针找到了一次对应目标后,把可能重复的数字跳过去。

明确了思路,代码就非常好写了。

cpp代码

cpp 复制代码
class Solution {
public:
    vector<vector<int>> threeSum(vector<int>& nums) {
        //一是固定数+双指针,二是二分,三是去重  
        vector<vector<int>> res;
        if(nums.size()<3) return res;
        sort(nums.begin(),nums.end());
        for(int i=0;i<nums.size();i++)
        {
            if(nums[i]>0) break;
            if(i>0&&nums[i]==nums[i-1]) continue;
            int j=i+1,k=nums.size()-1;
            while(j<k)
            {
                if(nums[i]+nums[j]+nums[k]==0) 
                {
                    res.push_back({nums[i],nums[j],nums[k]});
                    while(j<k && nums[j]==nums[j+1]) j++;
                    while(j<k && nums[k]==nums[k-1]) k--;
                    j++;
                    k--;
                }
                else if(nums[i]+nums[j]+nums[k]<0)
                {
                    j++;
                }
                else
                {
                    k--;
                }
            }
        }
        return res;
    }
};

流程

是 否 指针相遇 未相遇 和小 和大 开始 输入数组 数组排序 固定第一个数 双指针查找 找到解? 保存结果 继续查找 固定下一数 判断和大小 左指针右移 右指针左移

相关推荐
yaoh.wang1 分钟前
力扣(LeetCode) 70: 爬楼梯 - 解法思路
python·算法·leetcode·面试·职场和发展·动态规划·递归
大佬,救命!!!4 分钟前
python对应sql操作
开发语言·python·sql·学习笔记·学习方法
Wilber的技术分享9 分钟前
【大模型实战笔记 8】深入理解 LangGraph:构建可持久化、多智能体的 LLM 工作流
人工智能·笔记·agent·langgraph·智能体开发
IT方大同9 分钟前
C语言选择控制结构
c语言·开发语言
名誉寒冰9 分钟前
深入理解fd_set:从基础到实战应用(Linux/C++)
java·linux·c++
A242073493011 分钟前
js模糊搜索
开发语言·javascript·ecmascript
波比:)12 分钟前
(概率)波利亚的罐子
笔记·数学
Learner__Q13 分钟前
每天五分钟:二分查找-LeetCode高频题解析_day4
python·算法·leetcode
yuhaiqun198914 分钟前
学AI Agent:从React模式到Plan框架,3条路径一次学透
人工智能·经验分享·笔记·react.js·机器学习·ai·aigc
智者知已应修善业16 分钟前
【字符串提取3个整数求和】2024-2-11
c语言·c++·经验分享·笔记·算法