标签:
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 4559 Accepted Submission(s): 1902
#include <cstdio> #include <cstring> #include <iostream> using namespace std; const int N = 3000010; int prime[N], isprime[N]; int phi[N]; void Get_phi() { int i, j, cnt = 0; for(i = 2; i < N; i++){ if(isprime[i] == 0){ prime[cnt++] = i; phi[i] = i-1; } for(j = 0; j < cnt && i*prime[j] < N; j++){ isprime[i*prime[j]]=1; if(i%prime[j]==0) phi[i*prime[j]]=phi[i]*prime[j]; else phi[i*prime[j]]=phi[i]*(prime[j]-1); } } } int main() { int a, b; Get_phi(); while(~scanf("%d %d", &a, &b)) { long long sum = 0; for(int i = a; i <= b; i++) sum += phi[i]; cout << sum << endl; } return 0; }
杭电2824--The Euler function(欧拉函数)
标签:
原文地址:http://www.cnblogs.com/fengshun/p/4764321.html