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

力扣454.四数相加Ⅱ

给你四个整数数组 nums1nums2nums3 和 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

  提示:

  • n == nums1.length
  • n == nums2.length
  • n == nums3.length
  • n == nums4.length

  • 1 <= n <= 200
  • -228 <= nums1[i], nums2[i], nums3[i], nums4[i] <= 228

题目分析

这道题给了我们俩个数组,让我们找出nums1[i] + nums2[j] + nums3[k] + nums4[l] == 0共有几组,关于存在性的问题我们很快就能想到哈希表。

解题思路

我们先把四个数组分成俩组,第一组和第二组中的所有元素俩俩相加得到的值存入哈希表中,而他们相加的值为键,对应的值便是出现次数,

​int ikey = nums1[i] + nums2[j];struct hashTable* tmp;HASH_FIND_INT(hashtable, &ikey ,tmp);if(tmp == NULL) {struct hashTable* tmp = malloc(sizeof(struct hashTable));tmp->key = ikey;tmp->val = 1;HASH_ADD_INT(hashtable,key,tmp);}else {tmp->val++;}}​

我们通过上面的代码判断,如果出现过,所对应的值‘+1,如果返回NULL说明没有出现过,对应值为1。这样我们就得到了储存着num1num2相加数据的哈希表,我们再与剩下俩个数组相加得到的值对比,如果他们俩相加的相反数在哈希表中存在,便对应nums1[i] + nums2[j] + nums3[k] + nums4[l] == 0再看他对应的次数,即得出答案。

struct hashTable {int key;int val;UT_hash_handle hh;
};
int fourSumCount(int* nums1, int nums1Size, int* nums2, int nums2Size, int* nums3, int nums3Size, int* nums4, int nums4Size) {struct hashTable* hashtable = NULL;for(int i = 0;i < nums1Size;++i) {for(int j = 0;j< nums2Size;j++) {int ikey = nums1[i] + nums2[j];struct hashTable* tmp;HASH_FIND_INT(hashtable, &ikey ,tmp);if(tmp == NULL) {struct hashTable* tmp = malloc(sizeof(struct hashTable));tmp->key = ikey;tmp->val = 1;HASH_ADD_INT(hashtable,key,tmp);}else {tmp->val++;}}}int ans = 0;for(int i = 0;i<nums3Size;i++){for(int j =0;j<nums4Size;j++){int ikey = -nums3[i]-nums4[j];struct hashTable* tmp;HASH_FIND_INT(hashtable,&ikey,tmp);if(tmp != NULL) {ans += tmp->val;}}}return ans;
}

http://www.dtcms.com/a/278958.html

相关文章:

  • idea删除的文件怎么找回
  • 【第一章编辑器开发基础第二节编辑器布局_1水平与垂直布局(1/4)】
  • git项目,有idea文件夹,怎么去掉
  • 【第一章编辑器开发基础第一节绘制编辑器元素_6滑动条控件(6/7)】
  • 衡石科技技术手册--仪表盘过滤控件详解
  • SpringBoot集成SAP,本地IDEA启动和Windows服务器部署
  • 第八章排序 选择题
  • 【HarmonyOS】元服务入门详解 (一)
  • 从“直觉抢答”到“深度思考”:大模型的“慢思考”革命,思维链、树、图如何让AI越来越像人?
  • 生产者消费者问题,详解(操作系统os)
  • 扩散生成基础原理(二)——DDPM概率去噪扩散模型
  • 1.2.1 面向对象详解——AI教你学Django
  • git 下载报错:fetch-pack: unexpected disconnect while reading sideband packet
  • 139-CNN-BiLSTM-Selfattention-ABKDE预测模型!
  • 深度学习基础:损失函数(Loss Function)全面解析
  • 搭建k8s高可用集群,“Unable to register node with API server“
  • LINUX714 自动挂载/nfs;物理卷
  • 侧链的出现解决了主链哪些性能瓶颈?
  • Android系统的问题分析笔记 - Android上的调试方式 debuggerd
  • .NET 9 GUID v7 vs v4:时间有序性如何颠覆数据库索引性能
  • 如何快速去除latex表格中的加粗
  • 杨辉三角的认识与学习
  • 图像修复:深度学习GLCIC神经网络实现老照片划痕修复
  • 未来手机会自动充电吗
  • 计算机毕业设计Java医学生在线学习平台系统 基于 Java 的医学生在线学习平台设计与开发 Java 医学在线教育学习系统的设计与实现
  • React 和 Vue的自定义Hooks是如何实现的,如何创建自定义钩子
  • CSP-S 模拟赛 17
  • 单片机(STM32-串口通信)
  • IP相关
  • CSS `:root` 伪类深入讲解