【优选算法】四数之和(双指针算法)

必须有为成功付出代价的决心,然后想办法付出这个代价。

目录

1.【题目链接】

2.【算法原理】

3.【代码】


1.【题目链接】

18. 四数之和 - 力扣(LeetCode)

2.【算法原理】

与前面三数之和原理很像

**解法一:**排序 + 暴力枚举 + 利用set去重(超时)

用四个for循环枚举出所有情况再去重。

解法二 :

  1. 排序
  2. 先固定一个数 a
  3. 剩下的范围进行 "三数之和" 算法,找到三个数使和等于 target - a(三数之和:先固定一个数 b,再利用双指针算法求剩下的数之和为 target - a - b)

注意:

  1. 去重:对 left、right、a、b 进行去重
  2. 不漏:在找到一种结果之后,left ++,right -- 继续寻找

3.【代码】

cpp 复制代码
class Solution {
public:
    vector<vector<int>> fourSum(vector<int>& nums, int target) {
        vector<vector<int>> ret;
        int n = nums.size();
        //1.排序
        sort(nums.begin(), nums.end());

        //2.先固定一个数a,在剩下的数里面利用三数之和等于target-a
        for (int i = 0; i < n; )
        {
            //先固定一个数b,在剩下的数里面利用双指针算法
            for (int j = i + 1; j < n; )
            {
                int left = j + 1, right = n - 1;
                //避免数据溢出,我们用long long类型
                long long count = (long long)target - nums[i] - nums[j];
                while (left < right)
                {
                    int sum = nums[left] + nums[right];
                    if (sum > count) right--;
                    else if (sum < count) left++;
                    else
                    {
                        ret.push_back({ nums[i],nums[j],nums[left++],nums[right--] });
                        //去重一,left和right
                        while (left < right && nums[left] == nums[left - 1]) left++;
                        while (left < right && nums[right] == nums[right + 1]) right--;
                    }
                }
                //去重二
                j++;
                while (j < n && nums[j] == nums[j - 1]) j++;
            }
            //去重三
            i++;
            while (i < n && nums[i] == nums[i - 1]) i++;
        }
        return ret;
    }
};

完------


看完算法原理一定要先自己尝试写代码,不要直接看,这样做很锻炼自己的代码能力。

前面的三数之和题如果理解透彻且代码能够自己写出来,其实这道四数之和题自己也是能够写出来的,就是这道题有一个数据溢出的问题解决一下就好了。

双指针算法就此结束了,下一个算法思想开始。。。

相关推荐
Code哈哈笑12 分钟前
【机器学习】从回声定位到优化引擎:蝙蝠算法在SVR超参数优化中的应用
人工智能·算法·机器学习·蝙蝠算法
HR Zhou16 分钟前
群体智能优化算法-沙丁鱼群优化算法(Salp Swarm Algorithm (SSA,含Matlab源代码)
算法·机器学习·matlab·优化·群体智能优化
最好的药物是乌梅27 分钟前
【蓝桥杯速成】| 12.回溯排列&N皇后
数据结构·算法·leetcode·蓝桥杯
LuckyAnJo43 分钟前
Leetcode-100 贪心算法
算法·leetcode·贪心算法
旧厂街小江1 小时前
LeetCode第93题:复原IP地址
c++·python·算法
合合技术团队1 小时前
理解文字识别:一文读懂OCR商业化产品的算法逻辑
大数据·人工智能·算法
是Dream呀1 小时前
TCN-Inception:基于时序卷积网络和Inception模块的传感器人体活动识别方法
后端·算法
一只码代码的章鱼1 小时前
数据结构与算法-图论-强连通分量(tarjan算法)
数据结构·算法·图论
LinkerLin1 小时前
零数据之谜:无需数据的Transformer架构搜索之旅
算法
Bonnie2 小时前
深入学习搜索树与字符匹配数据结构
算法·typescript