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 小时前
算法23.0
算法
共享家95274 小时前
数独系列算法
算法·深度优先
liebe1*15 小时前
C语言程序代码(四)
c语言·数据结构·算法
进击的圆儿5 小时前
递归专题4 - 网格DFS与回溯
数据结构·算法·递归回溯
程序猿20235 小时前
Python每日一练---第一天:买卖股票的最佳时机
算法
夏鹏今天学习了吗6 小时前
【LeetCode热题100(56/100)】组合总和
算法·leetcode·职场和发展
ZPC82106 小时前
opencv 获取图像中物体的坐标值
人工智能·python·算法·机器人
颇有几分姿色6 小时前
密码学算法分类指南
算法·密码学
绝无仅有6 小时前
某游戏大厂的 Redis 面试必问题解析
后端·算法·面试
微笑尅乐6 小时前
三种方法解开——力扣3370.仅含置位位的最小整数
python·算法·leetcode