【LeetCode-中等题】 454. 四数相加 II

文章目录

题目

方法一:哈希表

哈希表记录前两个数组的和以及出现次数,然后记录后面两个数组的和,成功将四数之和转换为两数之和

因为本题特殊在和是为0 的 所以后面的两个数组之和取反 如果能在map的key中存在,说明存在和为0 的情况,则结果集数量+1

java 复制代码
class Solution {
    public int fourSumCount(int[] nums1, int[] nums2, int[] nums3, int[] nums4) {
        int res = 0;  //结果集数量
        Map<Integer,Integer> map = new HashMap<>();//记录前两个数组的和以及出现次数
        for(int i : nums1)
            for(int j : nums2){
             if(!map.containsKey(i+j)) map.put(i+j,1);
             else map.put(i+j,map.get(i+j)+1);
        }

        //遍历后面两个数组取出各自的结果  然后再依次去加上map的key是否等于0,如果是 则将对应的次数加入结果集
        //因为这里已经把四数相加  简化成了两数相加了,并且相加结果要为0    那么他们之间要相加等于0   那么肯定是互为相反数的
        //那么只需要将后面的两个数组相加的和取反  再去map里面去匹配相同的key  取出次数即可
         for(int i : nums3)
            for(int j : nums4){
                int temp = (i+j)*-1;//取相反数
                if(map.containsKey(temp)) res+=map.get(temp);//得到相加为0 的数的次数
            }
            return res;
    }
}
相关推荐
get lend gua几秒前
游戏数据分析,力扣(游戏玩法分析 I~V)mysql+pandas
python·mysql·leetcode·游戏·数据分析
卷不动的打工仔2 分钟前
Ubuntu利用docker搭建Java相关环境问题记录
java·ubuntu·docker
我爱工作&工作love我14 分钟前
【深基18.例3】查找文献-图的储存与遍历
算法·深度优先·图论
百锦再17 分钟前
Android Studio 中文字大小的单位详解
android·xml·java·ide·app·android studio
心软且酷丶28 分钟前
leetcode:2899. 上一个遍历的整数(python3解法)
python·算法·leetcode
啾啾Fun29 分钟前
数据结构与算法学习导航
学习·算法
AI技术控39 分钟前
计算机视觉算法实战——基于YOLOv8的农田智能虫情测报灯害虫种类识别系统开发指南
人工智能·深度学习·算法·yolo·计算机视觉
一只叫煤球的猫41 分钟前
分布式-跨服务事务一致性的常见解决方案
java·分布式·后端
赤橙红的黄1 小时前
Spring编程式事务(本地事务)
java·数据库·spring
PHASELESS4111 小时前
Java排序算法百科全书:原理、实现与实战指南
java·数据结构·算法·排序算法