LeetCode 3164.优质数对的总数 II:哈希表+因式分解

【LetMeFly】3164.优质数对的总数 II:哈希表+因式分解

力扣题目链接:https://leetcode.cn/problems/find-the-number-of-good-pairs-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

解题方法:哈希表+因式分解

遍历 n u m s 1 nums1 nums1数组,对于其中的元素 a a a,求出 ⌊ a k ⌋ \lfloor\frac{a}{k}\rfloor ka的所有因数并存入哈希表中。

遍历 n u m s 2 nums2 nums2数组,累加其中元素在哈希表中出现的次数即为答案。

如何求一个数 t t t的所有因数?

i i i 1 1 1 t \sqrt{t} t 枚举,若 t t t能整除 i i i,则说明 i i i t i \frac{\sqrt t}{i} it 都是 t t t的因数。

(这个过程有点类似“求一个数是否为质数”。)

  • 时间复杂度 O ( n M k + m ) O(n\sqrt{\frac Mk}+m) O(nkM +m),其中 M = max ⁡ ( n u m s 1 ) M=\max(nums1) M=max(nums1)
  • 空间复杂度 O ( M k ) O(\sqrt{\frac Mk}) O(kM )

AC代码

C++
typedef long long ll;
class Solution {
public:ll numberOfPairs(vector<int>& nums1, vector<int>& nums2, int k) {ll ans = 0;unordered_map<int, int> ma;for (int t : nums1) {if (t % k) {continue;}t /= k;int sqrt_ = sqrt(t);for (int i = 1; i <= sqrt_; i++) {if (t % i == 0) {ma[i]++;ma[t / i]++;}}if (sqrt_ * sqrt_ == t) {ma[sqrt_]--;}}for (int t : nums2) {ans += ma[t];}return ans;}
};
Go
package main
import "math"func numberOfPairs(nums1 []int, nums2 []int, k int) int64 {ma := map[int]int{}for _, t := range nums1 {if t % k != 0 {continue}t /= ksqrt_ := int(math.Sqrt(float64(t)));for i := 1; i <= sqrt_; i++ {if t % i == 0 {ma[i]++ma[t / i]++}}if sqrt_ * sqrt_ == t {ma[sqrt_]--}}ans := int64(0)for _, t := range nums2 {ans += int64(ma[t])}return ans
}
Java
import java.util.Map;
import java.util.HashMap;class Solution {public long numberOfPairs(int[] nums1, int[] nums2, int k) {Map<Integer, Integer> ma = new HashMap<>();for (int t : nums1) {if (t % k != 0) {continue;}t /= k;int sqrt_ = (int)Math.sqrt(t);for (int i = 1; i <= sqrt_; i++) {if (t % i == 0) {ma.merge(i, 1, Integer::sum);ma.merge(t / i, 1, Integer::sum);}}if (sqrt_ * sqrt_ == t) {ma.merge(sqrt_, -1, Integer::sum);}}long ans = 0;for (int t : nums2) {ans += (long)ma.getOrDefault(t, 0);}return ans;}
}
Python
from typing import List
from collections import defaultdict
from math import sqrtclass Solution:def numberOfPairs(self, nums1: List[int], nums2: List[int], k: int) -> int:ma = defaultdict(int)for t in nums1:if t % k:continuet //= ksqrt_ = int(sqrt(t))for i in range(1, sqrt_ + 1):if t % i == 0:ma[i] += 1ma[t // i] += 1if sqrt_ * sqrt_ == t:ma[sqrt_] -= 1ans = 0for t in nums2:ans += ma[t]return ans

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

Tisfy:https://letmefly.blog.csdn.net/article/details/142865441

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/56150.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

云原生后端

云原生后端&#xff08;Cloud-Native Backend&#xff09;是指在云计算环境中&#xff0c;利用云原生技术&#xff08;如容器、微服务、服务网格等&#xff09;构建和部署后端应用程序的一种方法。以下是对云原生后端的详细讲解&#xff1a; 1. 定义 云原生是一种设计和构建应…

基于Data+AI构建真正的流批一体!

基于DataAI构建真正的流批一体&#xff01; 前言流批一体的前世今生如何构建真正的流批一体架构数据架构统一数据处理引擎的选择数据治理与数据质量 流批一体的实践案例结语 前言 你是不是也有过这种感觉&#xff1f; 当你坐在电脑前&#xff0c;面对海量数据&#xff0c;心里…

zipkin启动脚本并指定mysql数据存储

#!/bin/bash# 配置部分 ############################################################## Zipkin JAR 文件的名称 # 这里指定了 Zipkin 的可执行 JAR 文件&#xff0c;确保该文件在当前目录中可用。 ZIPKIN_JAR"zipkin-server-2.23.2-exec.jar"# PID 文件的位置 # 该…

第十四届单片机嵌入式蓝桥杯

一、CubeMx配置 &#xff08;1&#xff09;LED配置 &#xff08;1&#xff09;LED灯里面用到了SN74HC573ADWR锁存器&#xff0c;这个锁存器有一个LE引脚,这个是我们芯片的锁存引脚&#xff08;使能引脚&#xff09;&#xff0c;由PD2这个端口来控制的 &#xff08;2&#xff…

Unity游戏通用框架——UI的管理和加载

需求&#xff1a;为了方便UI的管理&#xff0c;编写一个管理类&#xff0c;管理所有UI的加载、隐藏或销魂&#xff0c;每个UI都继承自一个UIWindow类&#xff0c;存放在Resource的指定目录下&#xff0c;通过UIManager进行管理。每个继承自UIWindow的UI天然有UI的打开关闭等基本…

阿里云CDN按峰值带宽计费和按流量计费哪个更划算

在选择阿里云CDN的计费方式时&#xff0c;按峰值带宽计费和按流量计费的划算程度主要取决于用户的具体使用场景。以下是两种计费方式的比较&#xff1a; 按流量计费 适用场景: 适合流量曲线波动较大、带宽利用率较低&#xff08;通常小于30%&#xff09;的用户。如果你的应用在…

Leetcode 1223 LCA of Deepest TreeNode

题意&#xff0c;找到所有最深的叶子节点的LCA https://leetcode.com/problems/lowest-common-ancestor-of-deepest-leaves/description/ 第一个想法是模块的想法, LCA 找到所有最深的叶子节点两两组合 可行&#xff0c;但是算法复杂度很高而且你先要从顶到下&#xff0c;再从…

Nullinux:一款针对Linux操作系统的安全检测工具

关于Nullinux Nullinux是一款针对Linux操作系统的安全检测工具&#xff0c;广大研究人员可以利用该工具针对Linux目标设备执行网络侦查和安全检测。 该工具可以通过SMB枚举目标设备的安全状况信息&#xff0c;其中包括操作系统信息、域信息、共享信息、目录信息和用户信息。如…

面对服务器掉包的时刻困扰,如何更好的解决

在数字化时代&#xff0c;服务器的稳定运行是企业业务连续性的基石。然而&#xff0c;服务器“掉包”现象&#xff0c;即数据包在传输过程中丢失或未能正确到达目的地的情况&#xff0c;却时常成为IT运维人员头疼的问题。它不仅影响用户体验&#xff0c;还可能导致数据不一致、…

PyQt 入门教程(2)搭建开发环境

文章目录 一、搭建开发环境1、安装PyQt6与pyqt6-tools2、配置外部工具QtDesigner与PYUIC 一、搭建开发环境 1、安装PyQt6与pyqt6-tools PyQt6&#xff1a; PyQt的开发库。pyqt6-tools&#xff1a; QtDesigner 设计器支撑库。 通过PyCharm安装开发库&#xff0c;命令如下&…

基于STM32 ARM+FPGA+AD的电能质量分析仪方案设计(一)硬件设计

电能质量分析系统硬件设计 3.1 电能质量分析系统设计要求 本系统实现对电能质量的高精度测量&#xff0c;根据国家相关电能质量分析仪器规定 标准以及对市场电能质量分析仪的分析&#xff0c;指定以下设计目标。 &#xff08; 1 &#xff09;电能质量参数测量精度&#xf…

k8s-配置网络策略 NetworkPolicy

在 Kubernetes (K8s) 中&#xff0c;NetworkPolicy 是一种用于控制 Pod 间网络流量以及 Pod 与外部网络之间的流量的资源对象。通过配置 NetworkPolicy&#xff0c;你可以在 Kubernetes 集群中实现基于网络的安全策略&#xff0c;类似防火墙规则。 1. NetworkPolicy 基础概念 …

PHP unset() 函数的作用

PHP 中的 unset() 函数用于销毁指定的变量。具体来说&#xff0c;它会解除变量名与其数据之间的关联&#xff0c;从而释放该变量所占用的内存。不过需要注意的是&#xff0c;unset() 并不是删除变量的内容&#xff0c;而是取消对变量名的引用。如果变量是数组中的某个元素或者对…

go发送邮件:在Go语言中实现发邮件的教程?

go发送邮件的教程指南&#xff1f;怎么使用Go语言发送电子邮件&#xff1f; Go语言&#xff0c;作为一种简洁、高效且并发性强的编程语言&#xff0c;自然也提供了丰富的库来支持邮件发送功能。AokSend将详细介绍如何在Go语言中实现发送邮件的功能&#xff0c;帮助你快速掌握这…

关于Git Bash中如何定义alias

一、在一次临时Bash会话中使用alias 在Bash中直接输入alias xxdddd&#xff0c;xx为对应要执行的命令的缩写&#xff0c;dddd为要执行的命令&#xff0c;如alias ddcd /d&#xff0c;输入完成后&#xff0c;在Bash中输入dd&#xff0c;即可切换至D盘。 此种设置方式&#xff…

armv7-a 异常排查

dfsr: data fault status register 发生异常时&#xff0c;该寄存器能够表示引起异常的原因&#xff0c;如非对齐访问、mmu translation fault 等等读取 dfsr 到 r[x] 寄存器 &#xff1a;mrc p15,0,r[x],c5,c0,0 dfar: data fault address register 保存了引起 data abort 异常…

RabbitMQ 入门(六)SpringAMQP五种消息类型

一、发布订阅-DirectExchange&#xff08;路由模式&#xff09; 在Fanout模式中&#xff0c;一条消息&#xff0c;会被所有订阅的队列都消费。但是&#xff0c;在某些场景下&#xff0c;我们希望不同的消息被不同的队列消费。这时就要用到Direct类型的Exchange。 Direct Exchan…

个性化图像生成新SOTA!阿里开源MIP-Adapter,可将无需微调的IP-Adapter推广到同时合并多个参考图像。

今天给大家介绍阿里最近开源的个性化图像生成的新方法MIP-Adapter&#xff0c;将无需微调的预训练模型&#xff08;IP-Adapter&#xff09;推广到同时合并多个参考图像。MIP-Adapter会根据每个参考图像与目标对象的相关性来给这些图像分配不同的“重要性分数”。这样&#xff0…

golang 报错:invalid character ‘‘ looking for beginning of object key string

这个错误通常表示我们的 Go 程序在解析 JSON 数据时&#xff0c;遇到了非法的字符&#xff0c;尤其是在需要找到 JSON 对象键时&#xff0c;遇到了 这样的非 ASCII 字符。这种情况可能是由于以下几个原因引起的&#xff1a; 可能原因&#xff1a; 编码问题&#xff1a;你的输…

Ngin入门套餐

快速了解Nginx 一、代理1.1 正向代理1.2 反向代理1.3 正向代理和反向代理的区别 二、Nginx负载均衡策略2.1 轮询&#xff08;Round Robin&#xff09;2.2 加权轮询&#xff08;Weighted Round Robin&#xff09;2.3 IP 哈希&#xff08;IP Hash&#xff09;2.4 最少连接&#x…