LeetCode454. 四数相加 II-Java&Go-哈希表

  • 算法
    • 1.HashMap
    • 2.遍历A数组和B数组元素,计算和存到Map中,key是元素之和,value是出现次数
    • 3.遍历C数组和D数组元素,从map中查找key是-(c+d)的键值对,value值即是一个四数相加和为0的一个元组
public int fourSumCount(int[] A, int[] B, int[] C, int[] D) {
    HashMap<Integer, Integer> map = new HashMap<>();
    for (int a : A) {
        for (int b : B) {
            map.put(a+b, map.getOrDefault(a+b, 0) + 1);
        }
    }

    int result = 0;
    for (int c : C) {
        for (int d : D) {
            result += map.getOrDefault(-(c+d), 0);
        }
    }
    return result;
}
func fourSumCount(A []int, B []int, C []int, D []int) int {
    dict := make(map[int]int)
    for _, a := range A {
        for _, b := range B {
            dict[a+b] += 1
        }
    }

    result := 0
    for _, c := range C {
        for _, d := range D {
            result += dict[-(c+d)]
        }
    }
    return result
}
LeetCode题解 文章被收录于专栏

测试

全部评论

相关推荐

11-03 15:31
门头沟学院 Java
斯卡蒂味的鱼汤:知道你不会来数马,就不捞你😂最近数马疯狂扩招,招聘要求挺低的,你能力肯定够,应该就是因为太强了,知道你不会来才不捞你
投递腾讯云智研发等公司10个岗位
点赞 评论 收藏
分享
10-28 10:48
已编辑
门头沟学院 Java
孩子我想要offer:发笔试后还没笔试把我挂了,然后邮箱一直让我测评没测,后面不知道干嘛又给我捞起来下轮笔试,做完测评笔试又挂了😅
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务