欧拉函数/狄利克雷卷积/积性函数


  

2705: [SDOI2012]Longge的问题

Time Limit: 3 Sec  Memory Limit: 128 MB
Submit: 1275  Solved: 820
[Submit][Status][Discuss]

Description

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

Input

一个整数,为N。

Output

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

Sample Input

6

Sample Output

15

HINT

【数据范围】

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

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

Source

[Submit][Status][Discuss]

  掉到莫比乌斯反演的坑里无法自拔,问了zyf&在网上看了题解才做出来TAT……我果然好弱

  这个题是要求$\sum_{x=1}^{n}gcd(x,n)$,考虑它的实际意义,我们可以得到$ans=\sum_{i|n}i*\varphi(\frac{n}{i})$

  但是明显φ函数我们是没法预处理的……($\frac{n}{i}$这玩意太大了),但考虑到n的约数不会太多,所以我们可以边找因数边计算φ。

  1. /**************************************************************
  2. Problem: 2705
  3. User: Tunix
  4. Language: C++
  5. Result: Accepted
  6. Time:16 ms
  7. Memory:804 kb
  8. ****************************************************************/
  9.  
  10. //BZOJ 2705
  11. #include<cmath>
  12. #include<cstdio>
  13. #define F(i,j,n) for(int i=j;i<=n;i++)
  14. typedef long long LL;
  15. LL phi(LL n){
  16. int ret=,i;
  17. for(int i=;i*i<=n;i++){
  18. if (n%i==){
  19. n/=i; ret*=i-;
  20. while(n%i==) n/=i,ret*=i;
  21. }
  22. }
  23. if (n>) ret*=n-;
  24. return ret;
  25. }
  26. int main(){
  27. int n;
  28. scanf("%d",&n);
  29. long long ans=;
  30. for(int i=;i*i<=n;i++)
  31. if(n%i==){
  32. ans+=(LL)i*phi(n/i);
  33. if (i*i<n) ans+=(LL)n/i*phi(i);
  34. }
  35. printf("%lld\n",ans);
  36. return ;
  37. }

  但是其实对于这个函数$\sum_{i|n} i*\varphi(\frac{n}{i})$是满足积性的,因为它就是$id(x)=x$和$\varphi(x)$这两个函数的狄利克雷卷积,那么……(贴个网上的图片)

  1. /**************************************************************
  2. Problem: 2705
  3. User: Tunix
  4. Language: C++
  5. Result: Accepted
  6. Time:8 ms
  7. Memory:816 kb
  8. ****************************************************************/
  9.  
  10. //BZOJ 2705
  11. #include<cmath>
  12. #include<cstdio>
  13. #define F(i,j,n) for(int i=j;i<=n;i++)
  14. int main(){
  15. int n;
  16. scanf("%d",&n);
  17. long long ans=n;
  18. F(i,,sqrt(n)){
  19. if(n%i==){
  20. int k=;
  21. for(k;n%i==;k++,n/=i);
  22. ans+=ans*(i-)*k/i;
  23. }
  24. }
  25. if (n!=) ans+=ans*(n-)*/n;
  26. printf("%lld\n",ans);
  27. return ;
  28. }

(诡异的加法版本)

P.S.但是这个【乘起来】的过程我在网上没找到啊……写法好诡异我理解不了……所以我机(sha)智(bi)地改了一个利用快速幂的版本= =耗时居然一样……如果有哪位路过的大牛搞明白了前面那个加法版本的意思的话请留言教我一下,万分感谢。

  1. /**************************************************************
  2. Problem: 2705
  3. User: Tunix
  4. Language: C++
  5. Result: Accepted
  6. Time:8 ms
  7. Memory:816 kb
  8. ****************************************************************/
  9.  
  10. //BZOJ 2705
  11. #include<cmath>
  12. #include<cstdio>
  13. #define F(i,j,n) for(int i=j;i<=n;i++)
  14. typedef long long LL;
  15. LL Pow(LL a,LL b){
  16. LL r=;
  17. for(;b;b>>=,a*=a)if(b&)r*=a;
  18. return r;
  19. }
  20. int main(){
  21. int n;
  22. scanf("%d",&n);
  23. LL ans=;
  24. F(i,,sqrt(n)){
  25. if(n%i==){
  26. int k=;
  27. for(k;n%i==;k++,n/=i);
  28. ans*=(k+)*Pow(i,k)-k*Pow(i,k-);
  29. // ans+=ans*(i-1)*k/i;
  30. }
  31. }
  32. if (n!=) ans*=*Pow(n,)-;
  33. printf("%lld\n",ans);
  34. return ;
  35. }

(乘法版本)

【BZOJ】【2705】【SDOI2012】Longge的问题的更多相关文章

  1. BZOJ 2705: [SDOI2012]Longge的问题 [欧拉函数]

    2705: [SDOI2012]Longge的问题 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 2553  Solved: 1565[Submit][ ...

  2. BZOJ 2705: [SDOI2012]Longge的问题

    2705: [SDOI2012]Longge的问题 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 2554  Solved: 1566[Submit][ ...

  3. BZOJ 2705: [SDOI2012]Longge的问题 GCD

    2705: [SDOI2012]Longge的问题 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnl ...

  4. bzoj 2705: [SDOI2012]Longge的问题 歐拉函數

    2705: [SDOI2012]Longge的问题 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 1035  Solved: 669[Submit][S ...

  5. Bzoj 2705: [SDOI2012]Longge的问题 欧拉函数,数论

    2705: [SDOI2012]Longge的问题 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 1959  Solved: 1229[Submit][ ...

  6. BZOJ 2705: [SDOI2012]Longge的问题( 数论 )

    T了一版....是因为我找质因数的姿势不对... 考虑n的每个因数对答案的贡献. 答案就是 ∑ d * phi(n / d) (d | n) 直接枚举n的因数然后求phi就行了. 但是我们可以做的更好 ...

  7. [bzoj]2705: [SDOI2012]Longge的问题[数论][数学][欧拉函数][gcd]

    [bzoj]P2705 OR [luogu]P2303 Longge的问题 Description Longge的数学成绩非常好,并且他非常乐于挑战高难度的数学问题.现在问题来了:给定一个整数N,你需 ...

  8. bzoj 2705: [SDOI2012]Longge的问题——欧拉定理

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

  9. BZOJ 2705 [SDOI2012]Longge的问题(欧拉函数)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2705 [题目大意] 求出∑gcd(i,N)(1<=i<=N) [题解] $ ...

  10. [bzoj 2705][SDOI2012]Longge的问题(数学)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=2705 分析: 设k为n的因数 设f[k]为gcd(x,n)==k的x的个数,容易知道a ...

随机推荐

  1. Entity Framework with NOLOCK

    在SqlServer中,频繁在同一个数据库表同时进行读写的时候,会存在锁的问题,也就是在前一个insert.update.delete事务操作完毕之前,你不能进行读取,必须要等到操作完毕,你才能进行s ...

  2. Incorrect column name 'productid '

    #1166 - Incorrect column name 'productid ' 解决方法:字段是复制的吧,复制的里面应该是有空格吧?检查一下,去掉就可以了哟,呵呵.  

  3. 魅族MX3问题集锦

    我第一台智能机已经服役2年半了,已经满足不了现在日益庞大的APP,所以打算让他光荣退役.我觉得IPhone仍然是目前做的最好的手机,但是对于我来说好像没什么必要,尤其那土豪般的价格.而且我平时看视频居 ...

  4. Internet Explorer 无法启用 JavaScript 怎么办?

    在 Internet Expllorer 8/9 中,有些同学在浏览网页时,收到提示:“需要启用 JavaScript …”,并且会发现网页上某些功能不能用了,比如点击网页里的按钮没反应等等. 怎么启 ...

  5. 入门级的PHP验证码

    参考了网上PHP 生成验证码很多是类封装了的,没有封装的验证码其实只是几个GD函数而已,初学者可以看看,可以尝试自己封装. <?php   session_start();      $im = ...

  6. 【转】Doscommand-操作Cmd的第三方控件

    核心用法: Doscommand1.CommandLine := 'cmd /c' +[命令];Doscommand1.OutputLines :=Memo1.Lines;Doscommand1.Ex ...

  7. API - .addBack()

    从jQuery官网上提供的Example来看,这个API的意思是: 1   先圈定一个范围,[A] $( "div.after-addback" ) 2 再用find过滤一出一个更 ...

  8. Delphi初学者应小心的六大陷阱

    Delphi初学者应小心的六大陷阱   作者:子夜编译       初学DelphiI的人,由于各种原因,对DelphiI中的许多概念不能很好的理解,并由此带来了许多的问题,或者是开发出的程序稳性不好 ...

  9. USB总线介绍

    •USB 1.0出现在1996年的,速度只有1.5Mb/s1998年升级为USB 1.1,速度也提升到12Mb/s,称之为”full speed” •USB2.0规范是由USB1.1规范演变而来的.它 ...

  10. 3.html5的文本元素

    如果你看了第一篇的内容,你会发现我的代码是这样的: 文本 <span>文本</span> <scolia>文本</scolia> <scolia ...