【BZOJ3309】DZY Loves Math
Time Limit: 5000 ms Memory Limit: 512 MB
Description
  
  	对于正整数n,定义f(n)为n所含质因子的最大幂指数。例如f(1960)=f(2^3 * 5^1 * 7^2)=3, f(10007)=1, f(1)=0。
  	给定正整数a,b,求\(\sum\limits _{i=1}^a \sum\limits_{j=1}^b f(gcd(i,j))\)。
  
Input
  
  第一行一个数T,表示询问数。
  接下来T行,每行两个数a,b,表示一个询问。
  
Output
  
  	对于每一个询问,输出一行一个非负整数作为回答。
  
Sample Input
  
  	4
  	7558588 9653114
  	6514903 4451211
  	7425644 1189442
  	6335198 4957
  
Sample Output
  
  	35793453939901
  	14225956593420
  	4332838845846
  	15400094813
  
HINT
  
【数据规模】
  T<=10000
  1<=a,b<=10^7
  
  
  
Solution
  
  这里用\(n\)和\(m\)代表题目中的\(a\)和\(b\)。-_-
ans&=\sum_{i=1}^n\sum_{j=1}^mf(gcd(i,j))\\
&=\sum_{x=1}^{min(n,m)}f(x)*sum(x) &sum(x)为x=gcd(i,j)的(i,j)对数,满足i和j在n和m范围内\\
&=\sum_{x=1}^{min(n,m)}f(x)\sum_{x|d}\mu(\frac dx)\lfloor\frac nd\rfloor\lfloor\frac md\rfloor\\
&=\sum_{x=1}^{min(n,m)}f(x)\sum_{k=1}^{\lfloor min(n,m)/x\rfloor}\mu(k)\lfloor\frac n{kx}\rfloor\lfloor\frac m{kx}\rfloor\\
&=\sum_{T=1}^{min(n,m)}\lfloor\frac nT\rfloor\lfloor\frac mT\rfloor\sum_{d|T}f(d)\mu(\frac Td)\\
&=\sum_{T=1}^{min(n,m)}\lfloor\frac nT\rfloor\lfloor\frac mT\rfloor g(T) &令g(x)=\sum\limits_{d|x}f(d)\mu(\frac xd)
\end{aligned}
\]
  
	现在关键是求解\(g\)函数,完事后求\(g\)的前缀和,一样根号分段求\(ans\).
  
	(1)当\(x\)为质数时,\(g(x)=f(1)\mu(x)+f(x)\mu(1)=0+1=1\)
  
  
  
  	(2)当筛到\(x=p*i\)时,分解质因数\(x=p_1^{q_1}p_2^{q_2}...p_k^{q_k}\),\(\frac xd=p_1^{a_1}p_2^{a_2}...p_k^{a_k}\),显然\(或a_i=0或1\),才能对\(g(x)\)有贡献,不然\(\mu({\frac xd})=0\). 现在只考虑满足\(或a_i=0或1\)的因数\(d\).
g(x)&=\sum_{d|x}f(d)\mu(\frac xd)\\
&=f(x)\sum_{d|x且f(d)=f(x)} \mu(\frac xd)+(f(x)-1)\sum_{d|x且f(d)\ne f(x)}\mu(\frac xd)\\
&=-\sum_{d|x且f(d)\ne f(x)}\mu(\frac xd)
\end{aligned}
\]
  	要满足\(f(d)\ne f(x)\),所有\(q_i=f(x)\)的\(p_i\)的指数在\(d\)中都要变成\(q_i-1\).
  
  1°  如果所有\(q_i=f(x)\),那么\(a_i\)全部取1,则\(g(x)=-\mu(p_1p_2...p_k)=-(-1)^k=(-1)^{k+1}\),这里有个特殊情况,如果\(i\)为\(p\)的完全平方数,即\(i=p^{a_i}\),(这里的\(a\)是最后提到的那个\(a\)数组),那么\(x=p^{a_i+1}\),则\(g(x)=-\mu(p)=1\)
  
  2°  否则若存在\(q_i\ne f(x)\),\(g(x)=0\).
  
  	记\(A=\{i|q_i=f(x)\},B=\{i|q_i\ne f(x)\}\).
  
  	对于\(A\)中的\(i\),\(a_i\)必须取1,而\(B\)中的\(a_i\)取0或1都可以,那么
g(x)&=-\sum\mu((\prod_{i\in A}p_i)*(\prod_{j\in B}(p_j或1))\\
&=-\mu(\prod_{i\in A}p_i)\sum\mu(\prod_{j\in B}(p_j或1))\\
&=-(-1)^{|A|}*0&\ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \prod_{i\in B}(p_j或1)有奇数个质数和偶数个质数的情况次数一样,正负抵消\\
&=0 &大快人心
\end{aligned}
\]
  	
  
  	线性筛时,维护一个\(a_i\)表示\(i\)的最小质因子\(p_{min}\)的指数,\(b_i\)表示\(p_{min}^{a_i}\).
  
  	由于每次循环的\(p\)都是\(x\)的最小质因子,故每次更新时比较\(a_i\)和\(a_x\)是否相同,如果相同就更新,如果不相同直接等于0,这样就可以保证每一个数\(x\)如果存在质因子指数不同的情况,\(g(x)\)立即等于0. 详情见代码.
  
  
  
#include <cstdio>
using namespace std;
typedef long long ll;
const int N=1e7+1;
int vis[N],lis[N],cnt;
ll g[N],a[N],b[N];
inline void swap(int &x,int &y){int t=x;x=y;y=t;}
inline int min(int x,int y){return x<y?x:y;}
void init(){
	for(int i=2;i<N;i++){
		if(!vis[i]){
			lis[++cnt]=i;
			a[i]=1; b[i]=i;
			g[i]=1;
		}
		for(int j=1;j<=cnt&&i*lis[j]<N;j++){
			int x=i*lis[j],p=lis[j];
			vis[x]=1;
			if(i%p==0){
              	//d是i去除p后的数,i=d*p^ai, x=d*p^(ai+1) 故ax=ai+1,bx相应乘上p
				a[x]=a[i]+1;
				b[x]=b[i]*p;
				int d=i/b[i];
				if(d==1) g[x]=1; //特殊情况(边界情况)i是p的幂
				else g[x]=(a[x]==a[d])?-g[d]:0;	 //若x满足所有指数相同,g(x)=g(d)乘上-1,否则为0
				break;
			}
			a[x]=1; b[x]=p;
			g[x]=a[i]==1?-g[i]:0; //原理同上
		}
	}
	for(int i=2;i<N;i++) g[i]+=g[i-1];
}
int main(){
	freopen("input.in","r",stdin);
	init();
	int T,a,b;
	ll ans;
	scanf("%d",&T);
	while(T--){
		scanf("%d%d",&a,&b);
		if(a>b) swap(a,b);
		ans=0;
		for(int i=1,j;i<=a;i=j+1){
			j=min(a/(a/i),b/(b/i));
			ans+=1LL*(a/i)*(b/i)*(g[j]-g[i-1]);
		}
		printf("%lld\n",ans);
	}
	return 0;
}
												
											【BZOJ3309】DZY Loves Math的更多相关文章
- 【BZOJ3309】DZY Loves Math(莫比乌斯反演)
		
[BZOJ3309]DZY Loves Math(莫比乌斯反演) 题面 求 \[\sum_{i=1}^a\sum_{j=1}^bf(gcd(a,b))\] 其中,\(f(x)\)表示\(x\)分解质因 ...
 - 【BZOJ3309】DZY Loves Math 解题报告
		
[BZOJ3309]DZY Loves Math Description 对于正整数\(n\),定义\(f(n)\)为\(n\)所含质因子的最大幂指数.例如\(f(1960)=f(2^3×5^1×7^ ...
 - 【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 莫比乌斯反演+线性筛
		
Description 对于正整数n,定义f(n)为n所含质因子的最大幂指数.例如f(1960)=f(2^3 * 5^1 * 7^2)=3, f(10007)=1, f(1)=0. 给定正整数a,b, ...
 - 【BZOJ3309】DZY Loves Math(线性筛)
		
题目: BZOJ 3309 分析: 首先,经过一番非常套路的莫比乌斯反演(实在懒得写了),我们得到: \[\sum_{T=1}^n \sum_{d|T}f(d)\mu(\frac{T}{d})\lfl ...
 - 【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 ...
 - 【BZOJ3561】DZY Loves Math VI (数论)
		
[BZOJ3561]DZY Loves Math VI (数论) 题面 BZOJ 题解 \[\begin{aligned} ans&=\sum_{i=1}^n\sum_{j=1}^m\sum_ ...
 - 【BZOJ3512】DZY Loves Math IV(杜教筛)
		
[BZOJ3512]DZY Loves Math IV(杜教筛) 题面 BZOJ 求 \[\sum_{i=1}^n\sum_{j=1}^m\varphi(ij)\] 其中\(n\le 10^5,m\l ...
 - 【bzoj3560】DZY Loves Math V  欧拉函数
		
题目描述 给定n个正整数a1,a2,…,an,求 的值(答案模10^9+7). 输入 第一行一个正整数n. 接下来n行,每行一个正整数,分别为a1,a2,…,an. 输出 仅一行答案. 样例输入 3 ...
 
随机推荐
- java.lang.ClassNotFoundException: com.radiadesign.catalina.session.RedisSessionHandlerValve
			
org.apache.tomcat.util.digester.Digester.startElement Begin event threw exception java.lang.ClassNot ...
 - 五、Html表单标签
			
表单,表单控件的主要作用就是收集用户体验,当用户提交表单时,用户输入的内容将作为请求参数提交到远程服务器. 1,form标签 <form>:创建表单,该元素不会生成可视化的界面,但是其他控 ...
 - linkin大话数据结构--Set
			
Set 集合 Set 集合不允许包含相同的元素,如果试把两个相同的元素加入同一个 Set 集合中,则添加操作失败. Set 判断两个对象是否相同不是使用 == 运算符,而是根据 equals 方法.也 ...
 - springMVC注解方式+easyUI+MYSQL配置实例
			
刚接触springMVC,使用的注解方式,也在学习阶段,所以把自己学习到的记下来.本文利用springMVC从数据库读取用户信息为例,分享一下. 1.准备相关架包及资源.因为使用springMVC+e ...
 - 04_Javascript初步第二天(上)
			
全局函数 isFinity() - 检测是否是无穷值(+infinity,-infinity,NaN返回false): isNaN() - 检测是否为数值 encodeURI(uri) - 将字符串编 ...
 - php与HTML交互问题
			
1.将表单中的action属性值设为PHP路径,则网页会跳转到这个网址 <html> <body> <form action="welcome.php" ...
 - java for循环增强(foreach)
			
for循环增强,在此之前还不知道foreach有这样的功能,先鄙视一下自己,留给自己看: 功能: ***若List用foreach : [ for(Student stu : list) ]这种形 ...
 - Cookie简述
			
1. Cookie是什么? Cookie(Cookies,浏览器缓存), 是指某些网站为了辨别用户身份.进行session跟踪而储存在用户本地终端上的数据(通常经过加密). 2. Cookie的作用: ...
 - iOS-属性字符串添加下划线、删除线
			
常用到的属性字符串 ///定义属性字符串NSMutableAttributedString *att = [[NSMutableAttributedString alloc]initWithStrin ...
 - CF 235C. Cyclical Quest [后缀自动机]
			
题意:给一个主串和多个询问串,求询问串的所有样子不同的周期同构出现次数和 没有周期同构很简单就是询问串出现次数,|Right| 有了周期同构,就是所有循环,把询问串复制一遍贴到后面啊!思想和POJ15 ...