LeetCode 15 三数之和

题目链接

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

题目解析

// 1. 排序+双指针

// 2. 固定一个值nums[i] 然后去剩下的位置去找 两数之和符合nums[j]+nums[k]是否等于-nums[i]

// 3. 细节问题:由于题目中是不可以包含重复的三元组的,因此我们需要对我们所选的三个数进行去重

代码

cpp 复制代码
class Solution 
{
public:
    vector<vector<int>> threeSum(vector<int>& nums) 
    {
        // 1. 排序+双指针
        // 2. 固定一个值nums[i] 然后去剩下的位置去找 两数之和符合nums[j]+nums[k]是否等于-nums[i]
        // 3. 细节问题:由于题目中是不可以包含重复的三元组的,因此我们需要对我们所选的三个数进行去重

        int n=nums.size();

        sort(nums.begin(),nums.end());
        vector<vector<int>> vv;
        vector<int> v;
        for(int i=0;i<n;)
        {
            int target=-nums[i];
            // 由于数组中的数据是升序的
            // 那么最小的数都是正数,那么后面的数都是正数
            // 因此就不可能会有三个数相加等于0
            if(nums[i]>0) break; // 当该值不符合情况直接跳出for循环
            int left=i+1,right=n-1;
            while(left<right)
            {
                int sum=nums[left]+nums[right];
                if(sum<target)
                {
                    left++;
                }
                else if(sum>target)
                {
                    right--;
                }

                // 当走到该位置的时候,那么这三个数就是符合条件的
                else
                {
                    v.clear();
                    v.push_back(nums[i]); v.push_back(nums[left]); v.push_back(nums[right]);
                    vv.push_back(v);
                    // vv.push_back({nums[i],nums[left],nums[right]});
                    left++;right--;
                    // 对两个指针进行去重
                    while(left<right&&nums[left]==nums[left-1]) left++;
                    while(left<right&&nums[right]==nums[right+1]) right--;
                }
               
            }
            // 对当前固定值进行去重
            i++;
            while(i<n&&nums[i]==nums[i-1])  i++;
        }
        return vv;
    }
};
相关推荐
咔咔学姐kk3 分钟前
大模型微调技术宝典:Transformer架构,从小白到专家
人工智能·深度学习·学习·算法·transformer
haogexiaole1 小时前
Dijkstra 算法
算法
papership3 小时前
【入门级-算法-6、排序算法: 插入排序】
数据结构·算法·排序算法
HAH-HAH3 小时前
【蓝桥杯 2024 国 Java A】粉刷匠小蓝
c++·学习·数学·算法·职场和发展·蓝桥杯·组合数学
hweiyu004 小时前
C++设计模式,高级开发,算法原理实战,系统设计与实战(视频教程)
c++·算法·设计模式
大千AI助手4 小时前
粒子群优化(PSO)算法详解:从鸟群行为到强大优化工具
人工智能·算法·优化算法·pso·粒子群优化
我叫汪枫5 小时前
C语言深度入门系列:第十一篇 - 动态内存管理与数据结构:程序世界的高效算法大师
c语言·数据结构·算法
Li_7695325 小时前
优选算法100 题 ——1 双指针
算法
77qqqiqi5 小时前
算法——数学基础
算法
啊?啊?5 小时前
7 排序算法通关指南:从 O (n²)(选择 / 冒泡)到 O (nlogn)(快排 / 归并)+ 计数排序
数据结构·算法·排序算法