215. 破译密码 - mobius函数 + 整数分块

2023-10-19 22:04

本文主要是介绍215. 破译密码 - mobius函数 + 整数分块,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 215. 破译密码 - AcWing题库

mobius函数:

一个数的分解质因数形式,某一个指数>1为0,质因数为奇数个为-1,偶数个为1 

mobius函数可以与容斥结合起来,比如mobius[2] = -1, mobius[3] = -1, mobius[2 * 3] = 1。对应容斥里面的加奇减偶。

如果a、b相同的话可以用欧拉函数做,不同的话就要另寻他法。

题目可以转化为1<=x<=a/d,1<=y<=b/d,满足gcd(x, y) = 1的对数

用容斥的思想:全部的组合-gcd为(2、3、5...)的+gcd为(6、10、15...)的...

设A = a / d, B = b / d

答案就为\sum_{i=1}^{min(A,B)}\frac{A}{i}*\frac{B}{i}*mobius[i],因为质因子形式某一项指数>1的mobius函数为0,所以等同于之前的容斥

然后用整数分块的思想降低时间复杂度,在一个区间内(A/i) * (B/i)的值是固定的,可以看成一个常数,此时mobius函数可以用前缀和来降低时间复杂度。

#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
#define endl '\n'using namespace std;typedef pair<int, int> PII;
typedef long long ll;
typedef long double ld;const int N = 50010;int a, b, d;
int primes[N], cnt;
bool st[N];
int mobius[N];void init(int n)
{mobius[1] = 1;for(int i = 2; i <= n; i ++){if(!st[i]){primes[cnt ++] = i;mobius[i] = -1;}for(int j = 0; primes[j] * i <= n; j ++){st[primes[j] * i] = true;if(i % primes[j] == 0){mobius[primes[j] * i] = 0;break;}mobius[primes[j] * i] = mobius[i] * -1;}}for(int i = 2; i <= n; i ++)mobius[i] += mobius[i - 1];
}void solve()
{cin >> a >> b >> d;a /= d, b /= d;ll ans = 0;int n = min(a, b);for(int l = 1, r; l <= n; l = r + 1){r = min(n, min(a / (a / l), b / (b / l)));ans += (ll)(mobius[r] - mobius[l - 1]) * (a / l) * (b / l);}cout << ans << endl;
}int main()
{IOSinit(N - 1);int _;cin >> _;while(_ --){solve();}return 0;
} 

这篇关于215. 破译密码 - mobius函数 + 整数分块的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/242643

相关文章

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

MySQL8 密码强度评估与配置详解

《MySQL8密码强度评估与配置详解》MySQL8默认启用密码强度插件,实施MEDIUM策略(长度8、含数字/字母/特殊字符),支持动态调整与配置文件设置,推荐使用STRONG策略并定期更新密码以提... 目录一、mysql 8 密码强度评估机制1.核心插件:validate_password2.密码策略级

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

MySQL中REPLACE函数与语句举例详解

《MySQL中REPLACE函数与语句举例详解》在MySQL中REPLACE函数是一个用于处理字符串的强大工具,它的主要功能是替换字符串中的某些子字符串,:本文主要介绍MySQL中REPLACE函... 目录一、REPLACE()函数语法:参数说明:功能说明:示例:二、REPLACE INTO语句语法:参数

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

python中update()函数的用法和一些例子

《python中update()函数的用法和一些例子》update()方法是字典对象的方法,用于将一个字典中的键值对更新到另一个字典中,:本文主要介绍python中update()函数的用法和一些... 目录前言用法注意事项示例示例 1: 使用另一个字典来更新示例 2: 使用可迭代对象来更新示例 3: 使用

Python lambda函数(匿名函数)、参数类型与递归全解析

《Pythonlambda函数(匿名函数)、参数类型与递归全解析》本文详解Python中lambda匿名函数、灵活参数类型和递归函数三大进阶特性,分别介绍其定义、应用场景及注意事项,助力编写简洁高效... 目录一、lambda 匿名函数:简洁的单行函数1. lambda 的定义与基本用法2. lambda

Python 函数详解:从基础语法到高级使用技巧

《Python函数详解:从基础语法到高级使用技巧》本文基于实例代码,全面讲解Python函数的定义、参数传递、变量作用域及类型标注等知识点,帮助初学者快速掌握函数的使用技巧,感兴趣的朋友跟随小编一起... 目录一、函数的基本概念与作用二、函数的定义与调用1. 无参函数2. 带参函数3. 带返回值的函数4.