454. 四数相加 II

给你四个整数数组 nums1、nums2、nums3 和 nums4 ,数组长度都是 n ,请你计算有多少个元组 (i, j, k, l) 能满足:0 <= i, j, k, l < nnums1[i] + nums2[j] + nums3[k] + nums4[l] == 0

思路:暴力模拟,四重for循环会超时,可以拆解为两个两重for循环

cpp 复制代码
class Solution {
public:
    int fourSumCount(vector<int>& nums1, vector<int>& nums2, vector<int>& nums3, vector<int>& nums4) {
        unordered_map<int,int> m;
        
        for(int a:nums1)
        {
            for(int b:nums2)
            {
                //m[a+b]将a+b存到key
                //m[a+b]++将a+b对应的value++
                m[a+b]++;
            }
        }
        int ans=0;
        for(int c:nums3)
        {
            for(int d:nums4)
            {
                if(m.find(0-c-d)!=m.end())
                {
                    ans+=m[0-c-d];
                }
            }
        }
        return ans;
    }
};
相关推荐
2301_8073671919 小时前
C++中的解释器模式变体
开发语言·c++·算法
愣头不青19 小时前
617.合并二叉树
java·算法
MIUMIUKK20 小时前
双指针三大例题
算法
灵感__idea20 小时前
Hello 算法:复杂问题的应对策略
前端·javascript·算法
2301_8194143021 小时前
C++与区块链智能合约
开发语言·c++·算法
Zaly.21 小时前
【Python刷题】LeetCode 1727 重新排列后的最大子矩阵
算法·leetcode·矩阵
不想看见40421 小时前
Valid Parentheses栈和队列--力扣101算法题解笔记
开发语言·数据结构·c++
做怪小疯子21 小时前
蚂蚁暑期 319 笔试
算法·职场和发展
计算机安禾21 小时前
【C语言程序设计】第37篇:链表数据结构(一):单向链表的实现
c语言·开发语言·数据结构·c++·算法·链表·蓝桥杯
啊哦呃咦唔鱼21 小时前
LeetCode hot100-73 矩阵置零
算法