zoukankan      html  css  js  c++  java
  • 洛谷 P2303 [SDOi2012]Longge的问题 解题报告

    P2303 [SDOi2012]Longge的问题

    题目背景

    SDOi2012

    题目描述

    Longge的数学成绩非常好,并且他非常乐于挑战高难度的数学问题。现在问题来了:给定一个整数(N),你需要求出(sum gcd(i, N)(1<=i <=N))

    输入输出格式

    输入格式:

    一个整数,为N。

    输出格式:

    一个整数,为所求的答案。

    说明

    对于60%的数据,0<N<=2^16

    对于100%的数据,0<N<=2^32


    问题很简短求(sum_{i=1}^n gcd(i,n))

    先暴力枚举(n)的所有约数(d),讨论(d)可以产生的贡献

    (m)满足(gcd(m,n)=d),则有(gcd(m/d,n/d)=1)

    则这样的(m/d)的个数为(φ(n/d))

    所以(d)产生的贡献为(d*φ(n/d))

    则答案为(sum_{d|n} d*φ(n/d))


    Code:

    #include <cstdio>
    #include <cmath>
    #define ll long long
    ll n,r,ans;
    ll get(ll k)
    {
        ll eu=k;
        for(ll i=2;i*i<=k;i++)
        {
            if(k%i==0)
                eu=eu*(i-1)/i;
            while(k%i==0)
                k/=i;
        }
        if(k>1) eu=eu*(k-1)/k;
        return eu;
    }
    int main()
    {
        scanf("%lld",&n);
        r=sqrt(n);
        for(int i=1;i<=r;i++)
            if(n%i==0)
            {
                ans+=i*get(n/i);
                ans+=n/i*get(i);
            }
        if(r*r==n)
            ans-=r*get(n/r);
        printf("%lld
    ",ans);
        return 0;
    }
    

    2018.6.29

  • 相关阅读:
    Interesting Finds: 2009 01.15 ~ 01.17
    Interesting Finds: 2008.12.07
    Interesting Finds: 2008.12.31
    10月16号
    10月14号
    10月15号
    10月13号
    10月20号
    10月19号
    10月12号
  • 原文地址:https://www.cnblogs.com/butterflydew/p/9245138.html
Copyright © 2011-2022 走看看