码迷,mamicode.com
首页 > 其他好文 > 详细

BZOJ 2705: [SDOI2012]Longge的问题

时间:2017-12-20 14:01:06      阅读:165      评论:0      收藏:0      [点我收藏+]

标签:str   stream   ble   style   sqrt   efi   online   get   .com   

二次联通门 : BZOJ 2705: [SDOI2012]Longge的问题

 

 

 

 

/*
    BZOJ 2705: [SDOI2012]Longge的问题

    莫比乌斯反演
*/
#include <cstdio>
#include <iostream>
#include <cmath>
#define rg register
#define Max 10000010
typedef long long LL;
LL phi[Max], p[Max]; bool is[Max];
void Euler (int N)
{
    int C = 0; rg LL i, j, k; phi[1] = 1;
    for (i = 2; i <= N; ++ i)
    {
        if (!is[i]) p[++ C] = i, phi[i] = i - 1;
        for (j = 1; j <= C; ++ j)
        {
            if ((k = p[j] * i) > N) break;
            is[k] = true;
            if (i % p[j] == 0) { phi[k] = phi[i] * p[j]; break; }    
            else phi[k] = phi[i] * (p[j] - 1);
        }
    }
}
LL get (LL N)
{
    rg LL i, s = N;
    for (i = 2; i * i <= N; ++ i)
        if (N % i == 0)
            for (s -= s / i, N /= i; N % i == 0; N /= i);
    if (N > 1) s -= s / N;
    return s;
}
int main (int argc, char *argv[])
{
    LL N; std :: cin >> N; rg LL i;
    LL Answer = 0; Euler (sqrt (N) + 2);
    for (i = 1; i * i <= N; ++ i)
        if (N % i == 0)
        {
            if (i * i != N)
                Answer += phi[i] * (N / i);
            Answer += i * get (N / i);
        }
    std :: cout << Answer;    
    return 0;
}

 

BZOJ 2705: [SDOI2012]Longge的问题

标签:str   stream   ble   style   sqrt   efi   online   get   .com   

原文地址:http://www.cnblogs.com/ZlycerQan/p/8072646.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!