news 2026/4/16 16:40:55

LeetCode 454 - 四数相加 II

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode 454 - 四数相加 II


文章目录

    • 摘要
    • 描述
      • 约束信息很关键
    • 题解答案(核心思路)
      • 关键拆分思路
      • 整体策略
    • 题解答案(Swift 可运行 Demo)
    • 题解代码分析
      • 1. 为什么要用字典?
      • 2. 第一阶段:构建和的“频率表”
      • 3. 第二阶段:查补数并累加
      • 4. 为什么这样不会漏算或重复算?
    • 示例测试及结果
      • 示例 1
      • 示例 2
      • 自定义测试
    • 实际场景结合
      • 1. 多条件组合统计
      • 2. 典型的“中间结果缓存”
      • 3. 面试中的信号题
    • 时间复杂度
    • 空间复杂度
    • 总结

摘要

LeetCode 454 是一道非常典型的“用空间换时间”的题。

如果你第一次看这道题,很容易写出一个四重循环,然后立刻发现:
完了,直接超时。

但这题真正考的不是暴力,而是你能不能意识到一件事:

四个数的和为 0,其实可以拆成两部分的和互相抵消

一旦你从A + B + C + D = 0转成
(A + B) = -(C + D)
这道题的复杂度立刻从“不可做”变成了“非常稳”。

描述

题目给了你四个长度相同的整数数组:

  • nums1
  • nums2
  • nums3
  • nums4

要求你统计有多少个四元组(i, j, k, l),满足:

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

约束信息很关键

  • 每个数组长度n <= 200
  • 数值范围是[-2^28, 2^28]

这意味着什么?

  • 四重循环是O(n^4),最大是200^4,根本跑不完
  • 必须降到O(n^2)级别

题解答案(核心思路)

关键拆分思路

把四个数组拆成两组:

  • 第一组:nums1+nums2
  • 第二组:nums3+nums4

目标条件:

a + b + c + d = 0

等价于:

(a + b) = -(c + d)

整体策略

  1. 枚举nums1nums2的所有和,记录每个和出现的次数
  2. 枚举nums3nums4的所有和
  3. 对于每个(c + d),查表看有没有-(c + d)
  4. 累加出现次数

这一步的本质是:
把四数问题,降维成两个“两数之和”的问题。

题解答案(Swift 可运行 Demo)

classSolution{funcfourSumCount(_nums1:[Int],_nums2:[Int],_nums3:[Int],_nums4:[Int])->Int{varsumMap:[Int:Int]=[:]// 1. 统计 nums1 + nums2 的所有可能和forainnums1{forbinnums2{letsum=a+b sumMap[sum,default:0]+=1}}varresult=0// 2. 枚举 nums3 + nums4,寻找补数forcinnums3{fordinnums4{lettarget=-(c+d)ifletcount=sumMap[target]{result+=count}}}returnresult}}

题解代码分析

1. 为什么要用字典?

varsumMap:[Int:Int]=[:]

这里的字 considered 是:

  • key:nums1[i] + nums2[j]
  • value:这个和出现的次数

因为:

  • 同一个和可能来自不同下标组合
  • 每一种组合都要算进答案

2. 第一阶段:构建和的“频率表”

forainnums1{forbinnums2{letsum=a+b sumMap[sum,default:0]+=1}}

这一段做的事情很单纯:

  • 枚举所有(i, j)
  • a + b当成一个“中间结果”缓存起来

这一步的复杂度是:

O(n²)

3. 第二阶段:查补数并累加

lettarget=-(c+d)ifletcount=sumMap[target]{result+=count}

这里非常关键的一点是:

  • 不是+1
  • 而是+count

原因是:

  • 可能有多个(a, b)对应同一个sum
  • 每一种都能和当前(c, d)组成一个合法四元组

4. 为什么这样不会漏算或重复算?

因为:

  • (a, b)只在第一阶段统计
  • (c, d)只在第二阶段枚举
  • 每个合法组合刚好被计算一次

示例测试及结果

示例 1

letsolution=Solution()letnums1=[1,2]letnums2=[-2,-1]letnums3=[-1,2]letnums4=[0,2]print(solution.fourSumCount(nums1,nums2,nums3,nums4))

输出:

2

示例 2

print(solution.fourSumCount([0],[0],[0],[0]))

输出:

1

自定义测试

print(solution.fourSumCount([1,-1],[-1,1],[0],[0]))

逻辑上:

(1 + -1) + (0 + 0) = 0 (-1 + 1) + (0 + 0) = 0

输出:

2

实际场景结合

这道题的思想在真实业务里非常常见。

1. 多条件组合统计

比如:

  • 用户行为 A
  • 用户行为 B
  • 用户行为 C
  • 用户行为 D

你想统计:
满足某个组合约束的用户数量

直接全量组合几乎一定炸。

2. 典型的“中间结果缓存”

  • 把复杂问题拆成两半
  • 把一半的结果预先算好并缓存
  • 用另一半去查表

这是很多高性能系统的基本套路。

3. 面试中的信号题

这道题非常适合用来区分:

  • 只会写暴力的人
  • 能主动做复杂度分析、拆问题的人

时间复杂度

  • 构建哈希表:O(n²)
  • 查找补数:O(n²)

总时间复杂度:

O(n²)

空间复杂度

  • 哈希表最多存个键值对

空间复杂度:

O(n²)

总结

LeetCode 454 的关键不在代码有多复杂,而在于你是否能意识到:

  • 四数问题 ≠ 四重循环
  • 拆分 + 哈希表是最稳的解法

如果你在刷题或写博客时,能把这道题讲清楚,基本就已经说明:

你不只是“会写题解”,而是真的理解了算法设计背后的思维方式。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 12:36:31

一文说清Multisim数据库与第三方EDA工具的兼容性问题

一文讲透Multisim与第三方EDA工具的数据协同难题你有没有遇到过这种情况&#xff1a;在Multisim里花了一周时间调通了一个精密放大电路&#xff0c;仿真结果完美——增益、带宽、噪声都符合预期。信心满满地准备导入Altium做PCB设计时&#xff0c;却发现元件引脚错乱、模型丢失…

作者头像 李华
网站建设 2026/4/16 12:36:34

Chrome网页文本替换插件:从基础到精通的完全实战指南

Chrome网页文本替换插件&#xff1a;从基础到精通的完全实战指南 【免费下载链接】chrome-extensions-searchReplace 项目地址: https://gitcode.com/gh_mirrors/ch/chrome-extensions-searchReplace 还在为网页上无法编辑的文本内容而束手无策&#xff1f;每次需要临时…

作者头像 李华
网站建设 2026/4/16 15:50:39

APK Editor Studio完全指南:从安装到精通Android应用编辑

APK Editor Studio完全指南&#xff1a;从安装到精通Android应用编辑 【免费下载链接】apk-editor-studio Powerful yet easy to use APK editor for PC and Mac. 项目地址: https://gitcode.com/gh_mirrors/ap/apk-editor-studio APK Editor Studio是一款功能强大的免费…

作者头像 李华
网站建设 2026/4/16 12:31:37

BetterNCM安装工具完整使用指南:快速提升网易云音乐体验

BetterNCM安装工具完整使用指南&#xff1a;快速提升网易云音乐体验 【免费下载链接】BetterNCM-Installer 一键安装 Better 系软件 项目地址: https://gitcode.com/gh_mirrors/be/BetterNCM-Installer BetterNCM Installer是一款专为网易云音乐用户设计的强大插件安装工…

作者头像 李华
网站建设 2026/4/16 12:58:04

BetterNCM安装器完整使用指南:轻松实现网易云音乐功能增强

BetterNCM安装器完整使用指南&#xff1a;轻松实现网易云音乐功能增强 【免费下载链接】BetterNCM-Installer 一键安装 Better 系软件 项目地址: https://gitcode.com/gh_mirrors/be/BetterNCM-Installer 还在为网易云音乐PC版功能单一而困扰吗&#xff1f;BetterNCM安装…

作者头像 李华
网站建设 2026/4/16 14:31:32

OpenEMS终极指南:快速掌握开源能源管理系统的完整教程

OpenEMS终极指南&#xff1a;快速掌握开源能源管理系统的完整教程 【免费下载链接】openems OpenEMS - Open Source Energy Management System 项目地址: https://gitcode.com/gh_mirrors/op/openems OpenEMS是一款革命性的开源能源管理系统&#xff0c;专门为分布式能源…

作者头像 李华