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;
    }
};
相关推荐
黑眼圈子4 小时前
总结一下用Java做算法的常用类和方法
java·开发语言·算法
apcipot_rain4 小时前
天梯赛练习集 时间规划 限时复盘 中档题详解(L1-6~L2-4)
算法
再卷也是菜4 小时前
第一章、线性代数(2)高斯消元法
线性代数·算法
NAGNIP4 小时前
一文搞懂CNN经典架构-EfficientNet!
算法·面试
如何原谅奋力过但无声4 小时前
【chap11-动态规划(上 - 基础题目&背包问题)】用Python3刷《代码随想录》
数据结构·python·算法·动态规划
小宇的天下5 小时前
Calibre LVS Circuit Comparison(2)
算法·lvs
迈巴赫车主5 小时前
求最大公约数-欧几里得算法(辗转相除法)
算法·最大公约数
lxl13076 小时前
C++算法(15)BFS_FloodFill
算法·宽度优先
小王C语言6 小时前
【基础IO】————简单设计一下libc库
前端·数据结构·算法
亦复何言??6 小时前
BeyondMimic 论文解析
人工智能·算法·机器人