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

【从零开始的LeetCode-算法】3164.优质数对的总数 II

给你两个整数数组 nums1nums2,长度分别为 nm。同时给你一个正整数 k

如果 nums1[i] 可以被 nums2[j] * k 整除,则称数对 (i, j)优质数对0 <= i <= n - 1, 0 <= j <= m - 1)。

返回 优质数对 的总数。

示例 1:

输入:nums1 = [1,3,4], nums2 = [1,3,4], k = 1

输出:5

解释:

5个优质数对分别是 (0, 0), (1, 0), (1, 1), (2, 0), 和 (2, 2)

示例 2:

输入:nums1 = [1,2,4,12], nums2 = [2,4], k = 3

输出:2

解释:

2个优质数对分别是 (3, 0)(3, 1)

提示:

  • 1 <= n, m <= 105

  • 1 <= nums1[i], nums2[j] <= 106

  • 1 <= k <= 103

class Solution {public long numberOfPairs(int[] nums1, int[] nums2, int k) {HashMap<Integer,Integer> map1 = new HashMap<Integer,Integer>();HashMap<Integer,Integer> map2 = new HashMap<Integer,Integer>();// 找出最大的除数int max_num = 0;// 使用map记录数组中所有数字及其出现的次数for(int num1: nums1){map1.put(num1,map1.getOrDefault(num1,0) + 1);if(num1 > max_num){max_num = num1;}}for(int num2: nums2){map2.put(num2,map2.getOrDefault(num2,0) + 1);}long count = 0;// 遍历所有被除数for(int num: map2.keySet()){int i = num * k;// 找出除数中,能与被除数组成优质数对的除数;即【被除数*k】的倍数for(int b = i; b <= max_num; b += i){// 优质数对的除数与被除数可以任意组合,可组成m*n个组合if( map1.containsKey(b)) count += 1L * map1.get(b) * map2.get(num);}}return count;}
}

http://www.lryc.cn/news/460454.html

相关文章:

  • FastDFS VS MinIO:文件存储与对象存储的抉择(包含SpringBoot集成FastDFS范例)
  • 【Redis】缓存预热、雪崩、击穿、穿透、过期删除策略、内存淘汰策略
  • 【LeetCode】每日一题 2024_10_15 三角形的最大高度(枚举、模拟)
  • 2024版最新网络安全工程师入门教程(非常详细)从零基础入门到精通,看完这一篇就够了
  • vue中关于router.beforeEach()的用法
  • C++模板初阶,只需稍微学习;直接起飞;泛型编程
  • 【数据结构 | 红黑树】红黑树的性质和插入结点时的调整
  • mysql学习教程,从入门到精通,SQL导入数据(44)
  • 【SpringAI】(二)让你的Java程序接入大模型——适合Java宝宝的大模型应用开发
  • 音频剪辑在线工具 —— 让声音更精彩
  • ​http短连接和长连接​
  • 日志分析删除
  • DART: Implicit Doppler Tomography for Radar Novel View Synthesis 笔记
  • redis-cli执行lua脚本
  • MySQL9的3个新特性
  • 《网络基础之 HTTP 协议:状态码含义全解析》
  • java真的正在越来越失去竞争力了吗
  • 【通过zip方式安装mysql服务】
  • 每日OJ题_WY3小易的升级之路_数学模拟_C++_Java
  • python xml的读取和写入
  • WebGL 小白入门学习
  • OSI七层协议
  • 超平面(Hyperplane)和半空间(Halfspace)
  • TCP(Transmission Control Protocol,传输控制协议)整理
  • R语言绘制线性回归图
  • C++进阶:map和set的使用
  • 深入理解C++ STL中的 vector
  • MySQL 安装与配置详细教程
  • 理解智能合约:区块链在Web3中的运作机制
  • QT工程概述