【BZOJ】3309: DZY Loves Math 莫比乌斯反演优化
3309: DZY Loves Math
Description
对于正整数n,定义f(n)为n所含质因子的最大幂指数。例如f(1960)=f(2^3 * 5^1 * 7^2)=3, f(10007)=1, f(1)=0。
给定正整数a,b,求sigma(sigma(f(gcd(i,j)))) (i=1..a, j=1..b)。
Input
第一行一个数T,表示询问数。
接下来T行,每行两个数a,b,表示一个询问。
Output
对于每一个询问,输出一行一个非负整数作为回答。
Sample Input
7558588 9653114
6514903 4451211
7425644 1189442
6335198 4957
Sample Output
14225956593420
4332838845846
15400094813
HINT
【数据规模】
T<=10000
1<=a,b<=10^7
参考博文:PoPoQQQ
盗的
我主要讲讲为什么只有在当T素因数分解所有的幂指数都相等时才会有(-1)k+1的贡献;
为了能将内层循环优化掉,就需要将a,b提出来,预处理;这时就变成第三步了,对T质因数分解为 T = p1^a1*p2^a2*...*pk^ak;
有莫比乌斯反演公式易知,d|T要使得mu[T/d] != 0只有每一个素因子的系数均 <= 1才行,这时总的d 的取法就为2k(k为T质因子的个数);
<1>当a1 = ... = ak = a时,对于f[d]易知只有当全部取的都是a-1时,才为a-1,这时只有一种情况;贡献为(a-1)*(-1)^k = a*(-1)^k + (-1)^k;
f[d] = a需要用组合数求解;(组合数为C(k,i),其中i表示取a-1的个数,即i = 0,1,...,k-1),这里i != k;(i = k时就是f[d] = a-1了),
这时的贡献为a*((-1)^0*C(k,0)+(-1)^1*C(k,1)+...+(-1)^(k-1)*C(k,k-1)) = ?
直接看(1-1)^K就会发现少了a*(-1^k*C(K,K)) = a*(-1)^k,所以加上第一种情况之后,需要-(-1)^k = (-1)k+1
<2> 当存在ai != aj时,最大幂无论去a还是a-1都是f[d]的取值,所以不可能出现分情况讨论,这时其他的去aj | aj-1都会造成奇偶的变化而使得f[d]变为0;
所以结论就是只有a1 = a2 = ... = ak = a时,Σf[d]*μ(T/d)才不为0,且f[d]是不需要计算的,要得到的只是k的奇偶 = > (-1)^(k+1)
预处理时间复杂度与筛法相同O(n);之后每组数据处理时间为O(sqrt(n)),即分块加速;
编码的细节:里面使用了递推来得到g[]:得到当前值为0还是1;即(-1)^(k+1),之后使用前缀和是为了分块加速;
同样递推还用在了a[i] : i的最小质因子的幂指数;val[i]:i最小质因子的幂指数乘积即p1^a1,这是为了在之后得到g[i]的时候,判断a[i] ?= a[j/val[i]]即最小的质因子的幂指数是否和倒数第二小的幂指数相等。注意这里是递推关系,即并不是只比较了最小的两个幂指数,就相当于马尔科夫链一样~~继承下来了~~(只是看别人的code的理解)巧妙 orz
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<stdlib.h>
using namespace std;
#define rep0(i,l,r) for(int i = (l);i < (r);i++)
#define rep1(i,l,r) for(int i = (l);i <= (r);i++)
#define rep_0(i,r,l) for(int i = (r);i > (l);i--)
#define rep_1(i,r,l) for(int i = (r);i >= (l);i--)
#define inf 0x7fffffff
typedef long long ll;
template<typename T>
void read1(T &m)
{
T x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
m = x*f;
}
template<typename T>
void read2(T &a,T &b){read1(a);read1(b);}
template<typename T>
void read3(T &a,T &b,T &c){read1(a);read1(b);read1(c);}
const int N = 1e7+;
int vis[N],g[N],p[N],a[N],val[N];
void init()
{
rep0(i,,N){
if(vis[i] == ){
p[++p[]] = i;
g[i] = ;
a[i] = ;
val[i] = i;
}
for(int j = ;p[j]*i < N;j++){
vis[i*p[j]] = ;
if(i%p[j] == ){
a[i*p[j]] = a[i]+;//最小质因数的幂指数;
val[i*p[j]] = val[i]*p[j];
int tmp = i/val[i];
if(tmp == ) g[i*p[j]] = ;//只有一个质因数
else
g[i*p[j]] = (a[tmp] == a[i*p[j]]?-g[tmp]:);
break;
}
a[p[j]*i] = ;//表示p[j]的次数为1;
val[i*p[j]] = p[j];
g[p[j]*i] = (a[i] == ?-g[i]:);
}
}
rep0(i,,N) g[i] += g[i-];
}
int main()
{
init();
int n,m,T,i,j;
read1(T);
while(T--){
read2(n,m);
ll ans = ;
if(n > m) swap(n,m);
for(i = ;i <= n;i = j + ){
j = min(n/(n/i),m/(m/i));
ans += 1LL*(g[j] - g[i-])*(n/i)*(m/i);
}
printf("%lld\n",ans);// I64d是会WA的,运行系统不同的结果..
}
return ;
}
【BZOJ】3309: DZY Loves Math 莫比乌斯反演优化的更多相关文章
- bzoj 3309 DZY Loves Math 莫比乌斯反演
DZY Loves Math Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 1303 Solved: 819[Submit][Status][Dis ...
- BZOJ 3309 DZY Loves Math ——莫比乌斯反演
枚举$d=gcd(i,j)$ 然后大力反演 ——来自Popoqqq的博客. 然后大力讨论后面的函数的意义即可. http://blog.csdn.net/popoqqq/article/details ...
- bzoj 3309 DZY Loves Math —— 莫比乌斯反演+数论分块
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3309 凭着上课所讲和与 Narh 讨论推出式子来: 竟然是第一次写数论分块!所以迷惑了半天: ...
- BZOJ 3309: DZY Loves Math [莫比乌斯反演 线性筛]
题意:\(f(n)\)为n的质因子分解中的最大幂指数,求\(\sum_{i=1}^n \sum_{j=1}^m f(gcd(i,j))\) 套路推♂倒 \[ \sum_{D=1}^n \sum_{d| ...
- BZOJ 3309: DZY Loves Math 莫比乌斯反演+打表
有一个神奇的技巧——打表 code: #include <bits/stdc++.h> #define N 10000007 #define ll long long #define se ...
- ●BZOJ 3309 DZY Loves Math
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=3309 题解: 莫比乌斯反演,线筛 化一化式子: f(x)表示x的质因子分解中的最大幂指数 $ ...
- BZOJ 3309: DZY Loves Math
3309: DZY Loves Math Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 761 Solved: 401[Submit][Status ...
- 【BZOJ3309】DZY Loves Math 莫比乌斯反演+线性筛(好题)
[BZOJ3309]DZY Loves Math Description 对于正整数n,定义f(n)为n所含质因子的最大幂指数.例如f(1960)=f(2^3 * 5^1 * 7^2)=3, f(10 ...
- 【BZOJ3309】DZY Loves Math - 莫比乌斯反演
题意: 对于正整数n,定义$f(n)$为$n$所含质因子的最大幂指数.例如$f(1960)=f(2^3 * 5^1 * 7^2)=3$,$f(10007)=1$,$f(1)=0$. 给定正整数$a,b ...
随机推荐
- java_泛型(设置通配符下限)
package ming; import java.util.ArrayList; import java.util.Collection; import java.util.List; /* * 返 ...
- windows共享文件夹如何让CentOS 6.5读取
http://www.111cn.net/sys/CentOS/74104.htm 工作需要,需要把本地win7共享的文件夹让CenotOS 6.5服务器临时使用一下,以下是CentOS 6.5系统挂 ...
- 在 Transact-SQL 中使用 TRY...CATCH
在 Transact-SQL 中使用 TRY...CATCH (注:本文来自于 http://msdn.microsoft.com/zh-cn/library/ms179296.aspx) ...
- ASP大数据量使用GetRows()提升速度
抽取10万条数据,Access数据库,GetRows() 现有10W条数据,Access数据库保存 通过正常提取: <% Set conn= Server.CreateObject(" ...
- C#学习笔记5:数据类型与进制转换
1.C#: 8种整形类型.2种用于科学计算的二进制浮点类型.1种用于金融计算的十进制浮点类型. 2.Decimal是一种特殊的浮点类型,能够存储大数字而无表示错误. 常用于货币计算.在表示的所有十进制 ...
- oracle-替换 换行符和空格符
--换行或空格: )), '') --换行及空格: update tableName set columnName= ), ), '')
- 文件上传~Uploadify上传控件
对于文件上传来说,有很多种实现方式,如传统的表单方式,现在流行的flash方式,甚至还有纯JS方式,之所以有这些方式来实现文件上传,我想主要原因是因为,传统的上传对于大文件支持不够,因为它是单线程同步 ...
- 使用SQL Server 2005 新的语法ROW_NUMBER()进行分页的两种不同方式的性能比较
相比在SQL Server 2000 中使用的分页方式,在SQL Server 2005中使用新的语法ROW_NUMBER()来分页效率要高出很多,但是很多人在使用ROW_NUMBER()这种分页方式 ...
- 17_JSP_入门
[JSP简述] JSP全称是Java Server Pages,它和Servlet技术一样,都是一种用于开发动态Web页面的技术. * html页面:用html写的页面 * JSP页面:用html写页 ...
- time 函数
1.Python Time 2.C++ Time Example: #include <iostream> #include <chrono> //C++的`计时`库 #inc ...