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;
    }
};
相关推荐
自然语1 分钟前
人工智能之数字生命-学习的过程
数据结构·人工智能·深度学习·学习·算法
Yuezero_12 分钟前
Research Intern面试(一)——手敲LLM快速复习
pytorch·深度学习·算法
wyiyiyi23 分钟前
【数据结构+算法】非递归遍历二叉树的理解
大数据·数据结构·笔记·算法·leetcode·数据分析
2401_8933266230 分钟前
力扣1971.寻找图中是否存在路径
算法·leetcode·职场和发展
zs宝来了39 分钟前
HOT100-技巧类型题
数据结构·算法
Ayanami_Reii39 分钟前
进阶数据结构-FenwickTree
数据结构·算法·树状数组·fenwick tree
爪哇部落算法小助手1 小时前
每日两题day59
数据结构·c++·算法
Brduino脑机接口技术答疑1 小时前
脑机接口数据处理连载(二) 数据源头解析:脑电信号的采集原理与数据特性
人工智能·python·算法·数据分析·脑机接口
吃着火锅x唱着歌1 小时前
LeetCode 1010.总持续时间可被60整除的歌曲
算法·leetcode·职场和发展