LeetCode 18 四数之和

题目链接

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

题目解析

固定两个数,然后利用双指针来进行剩下两个数的筛选

主要使用的是三数之和的思想,具体可以看我上篇博客

注意去重

代码

cpp 复制代码
class Solution 
{
public:
    vector<vector<int>> fourSum(vector<int>& nums, int target) 
    {
        // 排序
        sort(nums.begin(),nums.end());
        int n=nums.size();
        vector<vector<int>> ret;
        for(int i=0;i<n;)
        {
            // 固定第一个值
            int a=nums[i];
            for(int j=i+1;j<n;)
            {
                // 固定第二个值
                int b=nums[j];
                int left=j+1,right=n-1;
                // 可能会越界因此使用long long
                long long d=(long long )target-a-b;
                while(left<right)
                {
                    int c=nums[left]+nums[right];
                    if(c<d)
                    {
                        left++;
                    }
                    else if(c>d)
                    {
                        right--;
                    }
                    else
                    {
                        ret.push_back({a,b,nums[left],nums[right]});
                        left++;
                        right--;
                        // 去重
                        while(left<right&&nums[left]==nums[left-1]) left++;
                        while(left<right&&nums[right]==nums[right+1]) right--;
                    }
                }
                // 去重b
                j++;
                while(j<n&&nums[j]==nums[j-1]) j++;

            }
                // 去重a
                i++;
                while(i<n&&nums[i]==nums[i-1]) i++;
        }
        return ret;

    }
};
相关推荐
迷途之人不知返13 小时前
Stack & Queue
c++·算法
没文化的阿浩13 小时前
【数据结构】排序(2)——直接选择排序、堆排序
数据结构·算法·排序算法
ytttr87313 小时前
基于libusb的用户空间UVC相机库
算法
bybitq13 小时前
Reactor 模型 vs Proactor 模型:区别与代码示例
算法
jimy114 小时前
C 语言的 static 关键字作用
c语言·开发语言·算法
七颗糖很甜14 小时前
基于IRI-2016模型计算电子密度、TEC、foF2等参数的技术原理与代码实现
大数据·python·算法
风筝在晴天搁浅14 小时前
LeetCode 143.重排链表
算法·leetcode·链表
碧海银沙音频科技研究院14 小时前
如何彻底关闭360壁纸
人工智能·深度学习·算法
sali-tec14 小时前
C# 基于OpenCv的视觉工作流-章57-人脸识别
图像处理·人工智能·opencv·算法·计算机视觉
计算机安禾14 小时前
【Linux从入门到精通】第43篇:I/O调度算法与磁盘性能优化
linux·算法·性能优化