第四五四题_四数相加II

Map接口中的getOrDefault(Object key, V defaultValue)方法

当Map集合中有这个key时,就使用这个key对应的value值,如果没有就使用默认值defaultValue

题目

给定四个包含整数的数组列表 A , B , C , D ,计算有多少个元组 (i, j, k, l) ,使得 A[i] + B[j] + C[k] + D[l] = 0。
为了使问题简单化,所有的 A, B, C, D 具有相同的长度 N,且 0 ≤ N ≤ 500 。所有整数的范围在 -228 到 228 - 1 之间,最终结果不会超过 231 - 1 。

方法一:

思路: 将AB两个数组分为一组, CD为一组, 先遍历AB两个数组, 相加的值作为AB_Map的key, 结果出现的次数作为value; 然后再遍历CD, 当它们相加的相反数存在于AB_Map中的key, 则找到了一个满足题目条件的结果, 此时 count++, 最终count的值, 即为符合题目条件的所有结果的个数

class Solution {
    public int fourSumCount(int[] A, int[] B, int[] C, int[] D) {
        HashMap<Integer, Integer> AB_Map = new HashMap<>();
        int count = 0;
        for (int i = 0; i < A.length; i++) {
            for (int i1 = 0; i1 < B.length; i1++) {
                AB_Map.put(A[i] + B[i1],AB_Map.getOrDefault(A[i] + B[i1], 0) + 1);
            }
        }

        for (int c : C) {
            for (int d : D) {
                if(AB_Map.containsKey( -(c + d) )){
                 count = count + AB_Map.get( -(c + d) );
                }
            }
        }
        return count;
    }
}
posted @ 2020-11-27 19:30  无法手执玫瑰  阅读(31)  评论(0)    收藏  举报