题目:leetcode454. 四数相加 II
描述:
给你四个整数数组 nums1、nums2、nums3 和 nums4 ,数组长度都是 n ,请你计算有多少个元组 (i, j, k, l) 能满足:
0 <= i, j, k, l < n
nums1[i] + nums2[j] + nums3[k] + nums4[l] == 0
示例 1:
输入:nums1 = [1,2], nums2 = [-2,-1], nums3 = [-1,2], nums4 = [0,2]
输出:2
解释:
两个元组如下:
- (0, 0, 0, 1) -> nums1[0] + nums2[0] + nums3[0] + nums4[1] = 1 + (-2) + (-1) + 2 = 0
- (1, 1, 0, 0) -> nums1[1] + nums2[1] + nums3[0] + nums4[0] = 2 + (-1) + (-1) + 0 = 0
示例 2:
输入:nums1 = [0], nums2 = [0], nums3 = [0], nums4 = [0]
输出:1
思路:
还是使用map集合,在一个集合里面存放前两个数组的任意两个数之和(键),这个“和”出现的次数(值),最后使用两个for嵌套遍历后面两个数组得到k+l,使用0-k-l得到需要的值,在map里面查询这个值,查询到就说明前两个数组里面存在一个组合可以跟k+l相加得到0,所以count=count+从map取出的值(出现的次数),最后返回count。
import java.util.HashMap;
import java.util.Map;
public class Solution{
public int fourSumCount(int[] nums1, int[] nums2, int[] nums3, int[] nums4) {
int count=0;
Map<Integer,Integer> map=new HashMap<>();
for (int i :nums1) {
for (int j :nums2) {
// if(map.containsKey(sum)) {
// map.put(sum, map.get(sum) + 1);
// }
// else {
// map.put(sum, 1);
// }
//上面的注释的部分使用下面的一句来代替,节省了大部分时间
map.put(i+j,map.getOrDefault(i+j,0)+1);
}
}
for (int k:nums3) {
for (int l :nums4) {
count+=map.getOrDefault(0-k-l,0);
}
}
return count;
}
}