Description

很久很久以前,有一只神犇叫yzy;

很久很久之后,有一只蒟蒻叫lty;

Input

请你读入一个整数N;1<=N<=1E9,A、B模1E9+7;

Output

请你输出一个整数A=\sum_{i=1}^N{\mu (i^2)};

请你输出一个整数B=\sum_{i=1}^N{\varphi (i^2)};

Sample Input

1

Sample Output

1

1

Solution

完全不知道第一问是用来干嘛的。。。。反正都是1

第二问,显然,\(\varphi(i^2)=i\times\varphi(i)\)

于是就是求,\(\sum_{i=1}^ni\times\varphi(i)\)

套用杜教筛的式子,\(h=f*g\) ,在 \(f*g\) 中,\(\sum_{d|n}d\times\varphi(d)\times g(\frac{n}{d})\)

一种想法是试着把 \(\frac{n}{d}\) 给去掉,那么尝试着将 \(g\) 定为 \(id\)

那么 \(f*g\) 就变成了 \(n\sum_{d|n}\varphi(d)=n^2\)

带回杜教筛最后的那个式子,得到,\(S(n)=\sum_{i=1}i^2-\sum_{i=2}^niS(\lfloor\frac{n}{i}\rfloor)\)

杜教筛求就好了

  1. #include<bits/stdc++.h>
  2. #define ui unsigned int
  3. #define ll long long
  4. #define db double
  5. #define ld long double
  6. #define ull unsigned long long
  7. const int MAXN=10000000+10,Mod=1e9+7;
  8. int n,vis[MAXN],prime[MAXN],cnt,phi[MAXN];
  9. ll s[MAXN],inv6;
  10. std::map<int,ll> M;
  11. template<typename T> inline void read(T &x)
  12. {
  13. T data=0,w=1;
  14. char ch=0;
  15. while(ch!='-'&&(ch<'0'||ch>'9'))ch=getchar();
  16. if(ch=='-')w=-1,ch=getchar();
  17. while(ch>='0'&&ch<='9')data=((T)data<<3)+((T)data<<1)+(ch^'0'),ch=getchar();
  18. x=data*w;
  19. }
  20. template<typename T> inline void write(T x,char ch='\0')
  21. {
  22. if(x<0)putchar('-'),x=-x;
  23. if(x>9)write(x/10);
  24. putchar(x%10+'0');
  25. if(ch!='\0')putchar(ch);
  26. }
  27. template<typename T> inline void chkmin(T &x,T y){x=(y<x?y:x);}
  28. template<typename T> inline void chkmax(T &x,T y){x=(y>x?y:x);}
  29. template<typename T> inline T min(T x,T y){return x<y?x:y;}
  30. template<typename T> inline T max(T x,T y){return x>y?x:y;}
  31. inline void init()
  32. {
  33. memset(vis,1,sizeof(vis));
  34. vis[0]=vis[1]=0;
  35. phi[1]=1;
  36. for(register int i=2;i<MAXN;++i)
  37. {
  38. if(vis[i])
  39. {
  40. prime[++cnt]=i;
  41. phi[i]=i-1;
  42. }
  43. for(register int j=1;j<=cnt&&i*prime[j]<MAXN;++j)
  44. {
  45. vis[i*prime[j]]=0;
  46. if(i%prime[j])phi[i*prime[j]]=phi[i]*phi[prime[j]];
  47. else
  48. {
  49. phi[i*prime[j]]=phi[i]*prime[j];
  50. break;
  51. }
  52. }
  53. }
  54. for(register int i=1;i<MAXN;++i)s[i]=(s[i-1]+1ll*i*phi[i]%Mod)%Mod;
  55. }
  56. inline ll qexp(ll a,ll b)
  57. {
  58. ll res=1;
  59. while(b)
  60. {
  61. if(b&1)res=res*a%Mod;
  62. a=a*a%Mod;
  63. b>>=1;
  64. }
  65. return res;
  66. }
  67. inline ll S(int x)
  68. {
  69. if(x<MAXN)return s[x];
  70. if(M.find(x)!=M.end())return M[x];
  71. ll res=0;
  72. for(register int i=2;;)
  73. {
  74. if(i>x)break;
  75. int j=x/(x/i);
  76. (res+=(1ll*(i+j)*(j-i+1)/2)%Mod*S(x/i)%Mod)%=Mod;
  77. i=j+1;
  78. }
  79. return (1ll*x*(x+1)%Mod*(2*x+1)%Mod*inv6%Mod-res+Mod)%Mod;
  80. }
  81. int main()
  82. {
  83. read(n);init();inv6=qexp(6,Mod-2);
  84. printf("1\n%lld\n",S(n));
  85. return 0;
  86. }

【刷题】BZOJ 4916 神犇和蒟蒻的更多相关文章

  1. [BZOJ 4916]神犇和蒟蒻

    Description 很久很久以前,有一只神犇叫yzy; 很久很久之后,有一只蒟蒻叫lty; Input 请你读入一个整数N;1<=N<=1E9,A.B模1E9+7; Output 请你 ...

  2. bzoj 4916: 神犇和蒟蒻【欧拉函数+莫比乌斯函数+杜教筛】

    居然扒到了学长出的题 和3944差不多(?),虽然一眼看上去很可怕但是仔细观察发现,对于mu来讲,答案永远是1(对于带平方的,mu值为0,1除外),然后根据欧拉筛的原理,\( \sum_{i=1}^{ ...

  3. bzoj 4916: 神犇和蒟蒻 (杜教筛+莫比乌斯反演)

    题目大意: 读入n. 第一行输出“1”(不带引号). 第二行输出$\sum_{i=1}^n i\phi(i)$. 题解: 所以说那个$\sum\mu$是在开玩笑么=.= 设$f(n)=n\phi(n) ...

  4. LG4213 【模板】杜教筛(Sum)和 BZOJ4916 神犇和蒟蒻

    P4213 [模板]杜教筛(Sum) 题目描述 给定一个正整数$N(N\le2^{31}-1)$ 求 $$ans_1=\sum_{i=1}^n\varphi(i)$$ $$ans_2=\sum_{i= ...

  5. 【BZOJ4916】神犇和蒟蒻(杜教筛)

    [BZOJ4916]神犇和蒟蒻(杜教筛) 题面 BZOJ 求 \[\sum_{i=1}^n\mu(i^2)\ \ 和\ \sum_{i=1}^n\phi(i^2)\] 其中\[n<=10^9\] ...

  6. 【BZOJ4916】神犇和蒟蒻 解题报告

    [BZOJ4916]神犇和蒟蒻 Description 很久很久以前,有一群神犇叫sk和ypl和ssr和hjh和hgr和gjs和yay和xj和zwl和dcx和lyy和dtz和hy和xfz和myh和yw ...

  7. 【BZOJ4916】神犇与蒟蒻

    题面 Description 很久很久以前,有一只神犇叫yzy; 很久很久之后,有一只蒟蒻叫lty; Input 请你读入一个整数N;\(1<=N<=10^9\),A.B模\(10^9+7 ...

  8. BZOJ4916: 神犇和蒟蒻【杜教筛】

    Description 很久很久以前,有一只神犇叫yzy; 很久很久之后,有一只蒟蒻叫lty; Input 请你读入一个整数N;1<=N<=1E9,A.B模1E9+7; Output 请你 ...

  9. BZOJ4916 神犇和蒟蒻 【欧拉函数 + 杜教筛】

    题目 很久很久以前,有一只神犇叫yzy; 很久很久之后,有一只蒟蒻叫lty; 输入格式 请你读入一个整数N;1<=N<=1E9,A.B模1E9+7; 输出格式 请你输出一个整数A=\sum ...

随机推荐

  1. 编写Linux脚本

    下面是重新启动Linux下某进程的shell脚本.以tomcat进程为例: #!/bin/sh pid=`ps -ef|grep tomcat|grep -v grep|awk '{print $2} ...

  2. Liunx-cp命令

    1. 复制当前目录的test文件夹 到/201904 目录 出现如下截图问题是因为test目录下还有文件,所以得加-r,使用递归拷贝.我现在用这个命令拷贝文件都加-r了,不管有文件还是没文件 2.复制 ...

  3. 20155306 白皎 0day漏洞——漏洞利用原理之DEP

    20155306 白皎 0day漏洞--漏洞利用原理之DEP 一.DEP机制的保护原理 1.为什么出现DEP? 溢出攻击的根源在于现代计算机对数据和代码没有明确区分这一先天缺陷,就目前来看重新去设计计 ...

  4. mfc Edit控件属性

    设置Edit控件属性 窗口创建顺序 初始化Edit控件数据 一.设置Edit控件属性 .Align Text :Right 二.窗口创建顺序 CMywindowdlg: 窗口构造函数 OnCreate ...

  5. Eclipse中Maven插件配置

    1. Maven插件配置 http://www.blogjava.net/fancydeepin/archive/2012/07/13/eclipse_maven3_plugin.html 2. Ma ...

  6. openssh7.9 升级笔记

    由于全网安全检查需要,要对项目中1280台Linux系统升级SSH及openssl,其中: OPENSSH 升级为 openssh 7.9p 下载地址:  openssl 升级为 1.0.2o 下载地 ...

  7. 蓝牙disable流程简述

    蓝牙关闭的流程比打开流程要简单,主要就是一些profile的断连以及协议栈相关结构的释放. 这里简单说一下其流程,就直接从协议栈的disable的接口说起了. static int disable(v ...

  8. eclipse 最最最常用快捷键

    使用eclipse这么久,发现其跟PS一样,使用一些快捷键会有效率很多. 至此总结出以下每次打开eclipse基本都会用上的快捷键. 不熟悉这些快捷键,在实际编程中有意识使用的话对以后编码很有帮助. ...

  9. java 对象是可以判空的

    比如这里存xml,这里判断了一下element是否为空,来避免空指针异常,推荐用guava的optional判空

  10. PowerBI开发 第五篇:关系和交互

    PowerBI 使用 内存的列式数据库 VertiPaq,用于对已发布的数据集进行数据压缩和快速处理,能够使PowerBI报表执行脱机访问,面向列的处理,高度优化对1:N关系的处理性能.关系是数据分析 ...