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

相关文章

Python容器转换与共有函数举例详解

《Python容器转换与共有函数举例详解》Python容器是Python编程语言中非常基础且重要的概念,它们提供了数据的存储和组织方式,下面:本文主要介绍Python容器转换与共有函数的相关资料,... 目录python容器转换与共有函数详解一、容器类型概览二、容器类型转换1. 基本容器转换2. 高级转换示

pandas使用apply函数给表格同时添加多列

《pandas使用apply函数给表格同时添加多列》本文介绍了利用Pandas的apply函数在DataFrame中同时添加多列,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录一、Pandas使用apply函数给表格同时添加多列二、应用示例一、Pandas使用apply函

Python中Namespace()函数详解

《Python中Namespace()函数详解》Namespace是argparse模块提供的一个类,用于创建命名空间对象,它允许通过点操作符访问数据,比字典更易读,在深度学习项目中常用于加载配置、命... 目录1. 为什么使用 Namespace?2. Namespace 的本质是什么?3. Namesp

MySQL中如何求平均值常见实例(AVG函数详解)

《MySQL中如何求平均值常见实例(AVG函数详解)》MySQLavg()是一个聚合函数,用于返回各种记录中表达式的平均值,:本文主要介绍MySQL中用AVG函数如何求平均值的相关资料,文中通过代... 目录前言一、基本语法二、示例讲解1. 计算全表平均分2. 计算某门课程的平均分(例如:Math)三、结合

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

Python中isinstance()函数原理解释及详细用法示例

《Python中isinstance()函数原理解释及详细用法示例》isinstance()是Python内置的一个非常有用的函数,用于检查一个对象是否属于指定的类型或类型元组中的某一个类型,它是Py... 目录python中isinstance()函数原理解释及详细用法指南一、isinstance()函数

python中的高阶函数示例详解

《python中的高阶函数示例详解》在Python中,高阶函数是指接受函数作为参数或返回函数作为结果的函数,下面:本文主要介绍python中高阶函数的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录1.定义2.map函数3.filter函数4.reduce函数5.sorted函数6.自定义高阶函数

Python中的sort方法、sorted函数与lambda表达式及用法详解

《Python中的sort方法、sorted函数与lambda表达式及用法详解》文章对比了Python中list.sort()与sorted()函数的区别,指出sort()原地排序返回None,sor... 目录1. sort()方法1.1 sort()方法1.2 基本语法和参数A. reverse参数B.

Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧

《Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧》本文将通过实际代码示例,深入讲解Python函数的基本用法、返回值特性、全局变量修改以及异常处理技巧,感兴趣的朋友跟随小编一起看看... 目录一、python函数定义与调用1.1 基本函数定义1.2 函数调用二、函数返回值详解2.1 有返

Python Excel 通用筛选函数的实现

《PythonExcel通用筛选函数的实现》本文主要介绍了PythonExcel通用筛选函数的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录案例目的示例数据假定数据来源是字典优化:通用CSV数据处理函数使用说明使用示例注意事项案例目的第一