Leetcode 3312. Sorted GCD Pair Queries

ops/2024/10/18 8:27:07/
  • Leetcode 3312. Sorted GCD Pair Queries
    • 1. 解题思路
    • 2. 代码实现
  • 题目链接:3312. Sorted GCD Pair Queries

1. 解题思路

这一题的话坦率来说没有搞定,后来是找的大佬的代码抄了一下……

整体来说这道题思路上还是比较暴力的,还是一个二重循环,不过我是最暴力的二重循环,大佬稍微做了一下优化……

首先给出我的代码如下:

class Solution:def gcdValues(self, nums: List[int], queries: List[int]) -> List[int]:cnt = Counter(nums)nums = sorted(cnt.keys())m = max(nums)s = [0 for _ in range(m+1)]n = len(nums)for i in range(n):x = nums[i]s[x] += cnt[x] * (cnt[x]-1) // 2for j in range(i+1, n):y = nums[j]c = gcd(x, y)s[c] += cnt[x] * cnt[y]s = list(accumulate(s))return [bisect.bisect_right(s, q) for q in queries]

可以看到,就是两两求最大公约数,然后通过二分检索的方式求query的结果。而这个方法不出所料地超时了。

然后大佬们的优化点在于不是两两求最大公约数了,而是直接将所有可能的因数罗列出来,然后求每一个数作为最大公约数时的个数。

而对于具体的求法类似于求全部质数,即对每一个数,其作为最大公约数的个数为所有倍数上的数的个数总和取 C n 2 C_n^2 Cn2,然后减去其倍数上所有的数的最大公约数的数目。

如此一来的话差不多就是将时间复杂度从 O ( N 2 ) O(N^2) O(N2)减至 O ( N 3 / 2 ) O(N^{3/2}) O(N3/2)

2. 代码实现

给出python代码实现如下:

class Solution:def gcdValues(self, nums: List[int], queries: List[int]) -> List[int]:cnt = Counter(nums)nums = sorted(cnt.keys())m = max(nums)s = [0 for _ in range(m+1)]for i in range(m,0,-1):vc = sum(cnt[x] for x in range(i,m+1,i))vc = vc*(vc-1)//2 - sum(s[x] for x in range(i,m+1,i))s[i]=vcs = list(accumulate(s))return [bisect.bisect_right(s, q) for q in queries]

提交代码评测得到:耗时1627ms,占用内存42.2MB。


http://www.ppmy.cn/ops/124296.html

相关文章

数据结构 -- 跳表

文章目录 概要跳表的结构跳表的查找过程插入操作删除操作补充 概要 跳表(Skip List)是一种基于链表的数据结构,通过增加多级索引来加速查找、插入和删除操作。它可以看作是链表与二分查找的结合体,能够在保持数据有序的同时&…

探索CI/CD:持续集成与持续部署的基本概念

在现代软件开发中,持续集成(CI)和持续部署(CD)已经成为提高开发效率和产品质量的关键实践。本文将详细介绍CI/CD的基本概念、优势以及如何在实际项目中实施CI/CD。 一、什么是持续集成(CI)&…

ECMAScript与JavaScript的区别:深入解析与代码示例

目录 引言 ECMAScript与JavaScript的定义 ECMAScript JavaScript ECMAScript与JavaScript的关系 区别详解 定义上的区别 功能上的区别 实现上的区别 代码示例 ECMAScript 6 (ES6) 特性示例 箭头函数 模板字面量 JavaScript 特有的扩展 在Web开发中的应用 ECMAS…

【Unity基础】Unity用脚本实现内购(IAP)

本文介绍了如何使用脚本实现内购功能。 先看下脚本,代码中根据执行过程添加了序号。 using UnityEngine; using UnityEngine.Purchasing; using UnityEngine.UI;namespace Samples.Purchasing.Core.BuyingConsumables {public class BuyingConsumables : MonoBeha…

【Android】限制TextView大小并允许滑动

关于TextView大小限制 TextView本身支持大小限制,但只支持固定值 这里改用屏幕比例来判断,按照屏幕剩余空间的一定比例来现在TextView最大尺寸 TextView滑动 当TextView空间不足时,需要通过滑动来查看剩余文本 TextView默认是禁用滑动特…

QTday4

数据库头文件 #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include<QSqlDatabase> //数据库管理类 #include<QSqlQuery> //数据库查询类 #include<QSqlRecord> //记录类QT_BEGIN_NA…

使用aloam跑hesai Pandar-XT32激光雷达数据

参考自利用aloam跑数据集_aloam数据集-CSDN博客 第一步&#xff1a;查看bag的信息 输入rosbag info来查看bag包的信息&#xff1a; joeyjoey-Legion-Y7000P-IRX9:~$ rosbag info /home/joey/Downloads/data2022/indoor/LiDAR_IMU.bag path: /home/joey/Downloads/da…

【aws】从s3里拉取驱动 需要后台创建凭证

简答&#xff1a;建一个有s3readonlyaccess的role&#xff0c;绑定给e2就好了 详细步骤&#xff1a; 1.在控制台搜IAM----左侧导航栏点role/角色----右上角创建角色 2.使用案例里选EC2 3.搜s3readonlyaccess这个策略----创建角色 4.选中指定实例&#xff0c;设置&#xff0c;绑…