首页 > 其他 > 详细

BZOJ 1040 最大公约数之和

时间:2017-04-24 09:26:24      阅读:119      评论:0      收藏:0      [点我收藏+]

Description

求\(\sum_{i=1}^n(i,n),n\leqslant 10^9\)

Solution

\(\sum_{i=1}^n(i,n)=\sum_{d\mid n}d\sum_{i=1}^n[(i,n)=d]=\sum_{d\mid n}\sum_{i=1}^{\frac{n}{d}}[(i,\frac{n}{d})=1]=\sum_{d\mid n}\varphi(\frac{n}{d})\)

复杂度好像和杜教筛挺像的?口胡+1...我不太会算...

Code

#include <bits/stdc++.h>
using namespace std;

typedef long long ll;

ll phi(ll x) {
	ll r=x;
	for(int i=2;i*i<=x && x>1;i++) if(x%i==0) {
		r=r/i*(i-1),x/=i;
		for(;x%i==0;x/=i);
	}if(x>1) r=r/x*(x-1);return r;
}
ll S(ll n) { return n*(n+1)/2; }
ll S(ll l,ll r) { return S(r)-S(l-1); }
ll F(ll n) {
	ll r=0;
	for(int i=1;i*i<=n;i++) if(n%i==0) {
		r=r+i*phi(n/i);
		if(i*i==n) continue;
		r=r+n/i*phi(i);
	}return r;
}
int main() {
	ll n;
	scanf("%lld",&n);
	printf("%lld\n",F(n));
	return 0;
}

  

BZOJ 1040 最大公约数之和

原文:http://www.cnblogs.com/beiyuoi/p/6755024.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!