LeetCode 454.四数相加II

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

0 <= i, j, k, l < n

nums1[i] + nums2[j] + nums3[k] + nums4[l] == 0

示例 1:

输入:nums1 = [1,2], nums2 = [-2,-1], nums3 = [-1,2], nums4 = [0,2]

输出:2

解释:

两个元组如下:

  1. (0, 0, 0, 1) -> nums1[0] + nums2[0] + nums3[0] + nums4[1] = 1 + (-2) + (-1) + 2 = 0
  2. (1, 1, 0, 0) -> nums1[1] + nums2[1] + nums3[0] + nums4[0] = 2 + (-1) + (-1) + 0 = 0
    示例 2:

输入:nums1 = [0], nums2 = [0], nums3 = [0], nums4 = [0]

输出:1

提示:

n == nums1.length

n == nums2.length

n == nums3.length

n == nums4.length

1 <= n <= 200

-228^{28}28 <= nums1[i], nums2[i], nums3[i], nums4[i] <= 228^{28}28

我们可以把四个数组分为两组,i、j一组可以计算出n的平方个和,然后k、l一组也可以计算出n的平方个和,然后相当于两数之和为0,枚举一组中的值,找另一组中的值使得和为0即可:

cpp 复制代码
class Solution {
public:
    int fourSumCount(vector<int>& nums1, vector<int>& nums2, vector<int>& nums3, vector<int>& nums4) {
        unordered_map<int, int> cnt;

        int n = nums1.size();

        for (int i = 0; i < n; ++i) {
            for (int j = 0; j < n; ++j) {
                ++cnt[nums1[i] + nums2[j]];
            }
        }

        int ans = 0;

        for (int i = 0; i < n; ++i) {
            for (int j = 0; j < n; ++j) {
                int target = -nums3[i] - nums4[j];
                if (cnt.find(target) != cnt.end()) {
                    ans += cnt[target];
                }
            }
        }

        return ans;
    }
};

此算法时间复杂度为O(n2^22),空间复杂度为O(n2^22)。

相关推荐
yzp-1 分钟前
算法 198. 打家劫舍 ---------动态规划学习
算法
小小王app小程序开发15 分钟前
潮玩抽赏盲盒玩法开发全解析:算法、架构与合规风控
算法·架构
汉克老师19 分钟前
GESP2025年12月认证C++三级真题与解析(单选题1-8)
c++·算法·位运算·string·gesp三级·gesp3级·数据范围
技小宝21 分钟前
Excel网页抓取:批量获取亚马逊商品主图
大数据·经验分享·职场和发展·excel
week_泽23 分钟前
随机森林样本权重的计算-弱学习器
学习·算法·随机森林
Jasmine_llq26 分钟前
《P2151 [SDOI2009] HH 去散步》
算法·矩阵快速幂·快速幂算法 + 自定义矩阵乘法·图的邻接矩阵(边状态版)·状态拆分 + 转移条件·模运算(防溢出 + 结果取模)·二进制快速幂
The Last.H27 分钟前
Codeforces Round 1065 (Div. 3)A-C2
c++·算法
a程序小傲29 分钟前
米哈游Java面试被问:gRPC的HTTP/2流控制和消息分帧
java·开发语言·tcp/ip·http·面试·职场和发展·php
tudficdew41 分钟前
类型安全容器设计
开发语言·c++·算法
naruto_lnq41 分钟前
C++与Docker集成开发
开发语言·c++·算法