代码随想录算法【Day7】

DAY7

454.四数相加II

特点:

1.只用返回元组的个数,而不用返回具体的元组

2.可以不用去重

暴力思路:遍历,这样时间复杂度会达到O(n^4)

标准思路:用哈希法(场景:在一个集合里面判断一个元素是否出现过)

先遍历数组A、B,统计a+b的结果以及这个结果出现的次数,然后遍历数组C、D,判断0-(c+d)有没有在a+b的集合里面出现过。

复制代码
class Solution {
public:
    int fourSumCount(vector<int>& nums1, vector<int>& nums2, vector<int>& nums3, vector<int>& nums4) {
        unordered_map<int, int> umap; //<key, value>分别代表a+b的值,和这个值出现的次数
        for(int a : nums1)
            for(int b : nums2)
                umap[a + b] ++;
        //当访问一个不存在的键时,map 会自动为这个键创建一个新条目
        //新条目的值会被默认初始化,对于整型(int),默认初始化的值就是 0
        //所以不用去考虑给umap[a + b]设置一个初始值
        int count = 0; //最后的结果
        for(int c : nums3)
            for(int d :nums4)
                if(umap.find(0 - (c + d)) != umap.end())
                    count += umap[0 - (c + d)];
        return count;
    }
};
相关推荐
想逃离铁厂的老铁21 小时前
Day43 >> 300.最长递增子序列 + 674. 最长连续递增序列+ 718. 最长重复子数组
数据结构·算法
Yzzz-F21 小时前
P6648 [CCC 2019] Triangle: The Data Structure [st表]
算法
LateFrames1 天前
泰勒级数:从 “单点” 到 “理论与实践的鸿沟”
学习·算法
m0_726365831 天前
哈希分分预测系统 + Python Worker + Web 仪表盘”小系统(PHP + MySQL)
前端·python·哈希算法
武帝为此1 天前
【RC4加密算法介绍】
网络·python·算法
宵时待雨1 天前
数据结构(初阶)笔记归纳4:单链表的实现
c语言·开发语言·数据结构·笔记·算法
BLSxiaopanlaile1 天前
关于子集和问题的几种解法
数据结构·算法·剪枝·回溯·分解
狐571 天前
2026-01-17-LeetCode刷题笔记-3047-求交集区域内的最大正方形面积
笔记·算法·leetcode
Yzzz-F1 天前
P3509 [POI 2010] ZAB-Frog[单调队列+倍增快速幂思想]
算法
代码无bug抓狂人1 天前
C语言之5位黑洞数
c语言·算法