第四五四题_四数相加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;
}
}