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题解 文章被收录于专栏

测试

全部评论

相关推荐

10-27 17:26
东北大学 Java
点赞 评论 收藏
分享
双非坐过牢:非佬,可以啊10.28笔试,11.06评估11.11,11.12两面,11.19oc➕offer
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务