当前位置: 首页 > news >正文

leetcode454. 四数相加 II

题目: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
解释:
两个元组如下:

  1. (0, 0, 0, 1) -> nums1[0] + nums2[0] + nums3[0] + nums4[1] = 1 + (-2) + (-1) + 2 = 0
  2. (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;}
}
http://www.lryc.cn/news/122983.html

相关文章:

  • PHP证券交易员学习网站mysql数据库web结构apache计算机软件工程网页wamp
  • 对p-n结/AlGaN/GaN HEMTs中n-GaN掺杂浓度对栅极可靠性的影响
  • Mac M2 Pro安装使用Cocoapods
  • 枚举缓存工具
  • 【BASH】回顾与知识点梳理(二十五)
  • 什么是Node js?什么是React?有什么区别
  • 使用postman做接口测试
  • VMware Workstation 如何启用复制粘贴
  • 免费小程序商城搭建之b2b2c o2o 多商家入驻商城 直播带货商城 电子商务b2b2c o2o 多商家入驻商城 直播带货商城 电子商务 bbc
  • VSCode-Python传参数进行Debug
  • 实践-传统深度学习
  • 爬虫:使用Selenium模拟人工操作及获取网页内容
  • AOP开发
  • Streamlit项目: 轻松搭建部署个人博客网站
  • 手把手教你如何实现内网搭建电影网站并进行公网访问(保姆级教学)
  • Redis_事务操作
  • python质检工具(pylint)安装使用总结
  • “深入探究JVM:解密Java虚拟机的工作原理“
  • 同济子豪兄模板 半天搞定图像分类
  • 接口自动化测试,Fiddler使用抓包辅助实战,一篇彻底打通...
  • 概念解析 | 隐式神经表示:揭开神经网络黑盒的奥秘
  • 深入浅出PHP封装根据商品ID获取淘宝商品详情数据方法
  • 自动切换HTTP爬虫ip助力Python数据采集
  • 20230811导出Redmi Note12Pro 5G手机的录音机APP的录音
  • Python-OpenCV中的图像处理-傅里叶变换
  • 8.10 用redis实现缓存功能和Spring Cache
  • SPI协议个人记录
  • 【深度学习 video detect】Towards High Performance Video Object Detection for Mobiles
  • 时序预测 | MATLAB实现EEMD-LSTM、LSTM集合经验模态分解结合长短期记忆神经网络时间序列预测对比
  • 【软件工程】面向对象方法-RUP