51nod 1238 最小公倍数之和 V3

\[\sum_{i=1}^N\sum_{j=1}^N lcm(i,j)
\]

\(N\leq 10^{10}\)

先按照套路推一波反演的式子:

\[Ans=\sum_{g=1}g\sum_{i=1}^{\frac{n}{g}}\sum_{j=1}^{\frac{n}{g}}ij\sum_{d|i,d|j}\mu(d)\\
=\sum_{g=1}g\sum_{d=1}^{\frac{n}{g}}d^2\mu(d)S^2(\frac{n}{dg})\\
=\sum_{T=1}^n\sum_{d|T}d^2\mu(d)\frac{T}{d}S^2(\frac{n}{T})\\
\]

难点在于求下面的函数的前缀和。

\[G(n)=\sum_{d|T}d^2\mu(d)\frac{T}{d}
\]

设:

\[A(n)=n^2\mu(n)\\
B(n)=n
\]

则:

\[G(n)=A*B
\]

其中\(*\)表示狄利克雷卷积。

考虑用杜教筛,也就是构造一个函数\(C(n)\),使得\(G*C\)有些美妙的性质。

考虑从\(A(n)=n^2\mu(n)\)下手,将\(n^2\)消掉,只留下\(\mu(n)\)。

设\(C(n)=n^2\),

\[A*C=\sum_{d|n}d^2\mu(d)(\frac{n}{d})^2\\
=n^2\sum_{d|n}\mu(d)\\
=[n==1]
\]

所以:

\[\begin{align}
G*C&=(A*C)*B\\
&=\epsilon *B\\
&=\sum_{d=1}[d==1]\frac{n}{d}\\
&=n
\end{align}
\]

然后就是杜教筛的套路:

\[\sum_{i=1}^n\sum_{d|n}G(n)(\frac{n}{d})^2=\sum_{i=1}^ni\\
\Rightarrow \sum_{i=1}^ni^2\sum_{j=1}^{\lfloor\frac{n}{i}\rfloor}G(j)=\frac{n*(n+1)}{2}\\
\Rightarrow \sum_{i=1}^ni^2S_G(\lfloor\frac{n}{i}\rfloor)=\frac{n*(n+1)}{2}\\
\Rightarrow S_G(n)=\frac{n*(n+1)}{2}-\sum_{i=2}^ni^2S_G(\lfloor\frac{n}{i}\rfloor)\\
\]

代码:

  1. #include<bits/stdc++.h>
  2. #define ll long long
  3. #define maxx 3000005
  4. using namespace std;
  5. inline ll Get() {ll x=0,f=1;char ch=getchar();while(ch<'0'||ch>'9') {if(ch=='-') f=-1;ch=getchar();}while('0'<=ch&&ch<='9') {x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}return x*f;}
  6. const ll mod=1e9+7;
  7. ll ksm(ll t,ll x) {
  8. ll ans=1;
  9. for(;x;x>>=1,t=t*t%mod)
  10. if(x&1) ans=ans*t%mod;
  11. return ans;
  12. }
  13. ll n;
  14. int p[maxx];
  15. ll f[maxx];
  16. bool vis[maxx];
  17. const ll inv2=ksm(2,mod-2),inv6=ksm(6,mod-2);
  18. ll cal(ll n) {return n*(n+1)%mod*inv2%mod;}
  19. ll cal2(ll n) {return n*(n+1)%mod*(2*n+1)%mod*inv6%mod;}
  20. void pre(int n) {
  21. for(int i=2;i<=n;i++) {
  22. if(!vis[i]) p[++p[0]]=i,f[i]=1-i+mod;
  23. for(int j=1;j<=p[0]&&1ll*i*p[j]<=n;j++) {
  24. vis[i*p[j]]=1;
  25. if(i%p[j]==0) {
  26. f[i*p[j]]=f[i];
  27. break;
  28. }
  29. f[i*p[j]]=(1-p[j])*f[i]%mod;
  30. }
  31. }
  32. f[1]=1;
  33. for(int i=1;i<=n;i++) {
  34. f[i]=((f[i]*i+f[i-1])%mod+mod)%mod;
  35. }
  36. }
  37. map<ll,ll>st;
  38. ll Sum(ll n) {
  39. if(n<=3000000) return f[n];
  40. if(st.find(n)!=st.end()) return st[n];
  41. ll ans=cal(n%mod);
  42. ll last=1;
  43. for(ll i=2;i<=n;i=last+1) {
  44. ll now=n/(n/i);
  45. ans=(ans-(cal2(now%mod)-cal2(last%mod)+mod)*Sum(n/i)%mod+mod)%mod;
  46. last=now;
  47. }
  48. return st[n]=ans;
  49. }
  50. ll solve(ll n) {
  51. ll ans=0;
  52. ll last=0;
  53. for(ll i=1;i<=n;i=last+1) {
  54. ll now=n/(n/i);
  55. (ans+=(Sum(now)-Sum(last)+mod)*cal(n/i%mod)%mod*cal(n/i%mod))%=mod;
  56. last=now;
  57. }
  58. return ans;
  59. }
  60. int main() {
  61. pre(3000000);
  62. n=Get();
  63. cout<<solve(n);
  64. return 0;
  65. }

51nod 1238 最小公倍数之和 V3的更多相关文章

  1. 51NOD 1238 最小公倍数之和 V3 [杜教筛]

    1238 最小公倍数之和 V3 三种做法!!! 见学习笔记,这里只贴代码 #include <iostream> #include <cstdio> #include < ...

  2. 51nod 1238 最小公倍数之和 V3 【欧拉函数+杜教筛】

    首先题目中给出的代码打错了,少了个等于号,应该是 G=0; for(i=1;i<=N;i++) for(j=1;j<=N;j++) { G = (G + lcm(i,j)) % 10000 ...

  3. 51Nod 1238 最小公倍数之和V3

    题目传送门 分析: 现在我们需要求: \(~~~~\sum_{i=1}^{n}\sum_{j=1}^{n}lcm(i,j)\) \(=\sum_{i=1}^{n}\sum_{j=1}^{n}\frac ...

  4. 51Nod 1238 - 最小公倍数之和 V3(毒瘤数学+杜教筛)

    题目 戳这里 推导 ∑i=1n∑j=1nlcm(i,j)~~~\sum_{i=1}^{n}\sum_{j=1}^{n}lcm(i,j)   ∑i=1n​∑j=1n​lcm(i,j) =∑i=1n∑j= ...

  5. 【51nod】1238 最小公倍数之和 V3 杜教筛

    [题意]给定n,求Σi=1~nΣj=1~n lcm(i,j),n<=10^10. [算法]杜教筛 [题解]就因为写了这个非常规写法,我折腾了3天…… $$ans=\sum_{i=1}^{n}\s ...

  6. 51 NOD 1238 最小公倍数之和 V3

    原题链接 最近被51NOD的数论题各种刷……(NOI快到了我在干什么啊! 然后发现这题在网上找不到题解……那么既然A了就来骗一波访问量吧…… (然而并不怎么会用什么公式编辑器,写得丑也凑合着看吧…… ...

  7. 51 Nod 1238 最小公倍数之和 V3 杜教筛

    题目链接:http://www.51nod.com/Challenge/Problem.html#!#problemId=1238 题意:求$\sum_{i=1}^{n}\sum_{j=1}^{n}l ...

  8. [51Nod 1238] 最小公倍数之和 (恶心杜教筛)

    题目描述 求∑i=1N∑j=1Nlcm(i,j)\sum_{i=1}^N\sum_{j=1}^Nlcm(i,j)i=1∑N​j=1∑N​lcm(i,j) 2<=N<=10102<=N ...

  9. 【学术篇】51nod 1238 最小公倍数之和

    这是一道杜教筛的入(du)门(liu)题目... 题目大意 求 \[ \sum_{i=1}^n\sum_{j=1}^nlcm(i,j) \] 一看就是辣鸡反演一类的题目, 那就化式子呗.. \[ \s ...

随机推荐

  1. JQuery官方学习资料(译):Attributes

    Attributes     元素的属性可以为你的应用程序包含有用的信息,重要的是能够获取和设置它. .attr()方法     .attr()方法是可获取和可设置的,在设置状态下,.attr()可以 ...

  2. 第三讲 smart qq 登录成功后获取 vfwebqq ,psessionid,hash

    public static void Login_GetPHV() { string urldata = "{\"ptwebqq\":\"#{ptwebqq}\ ...

  3. JavaScript是如何工作的:Web Workers的构建块 + 5个使用他们的场景

    摘要: 理解Web Workers. 原文:JavaScript是如何工作的:Web Workers的构建块 + 5个使用他们的场景 作者:前端小智 Fundebug经授权转载,版权归原作者所有. 这 ...

  4. 2017 ACM-ICPC西安网赛B-Coin

    B-Coin Bob has a not even coin, every time he tosses the coin, the probability that the coin's front ...

  5. js 随机点名

    1.对象构造函数 设置节点与人名 constructor({ printElement, startElement, stopElement , person }) { this.list = per ...

  6. 三、HTTP基础路由详解

    1.一次请求的完整实现过程 2.基础路由 Route::get($uri,$callback); Route::post($uri,$callback); Route::put($uri,$callb ...

  7. html之多行文本textarea 及下拉框select(12)

    1.多行文本 多行文本使用textarea标签,默认值需要写在中间,和input标签不同,name属性用于后台获取数据(request.POST.get(meno)) <body> < ...

  8. tomcat闪退解决

    异常原因:拷贝了一个tomcat到新机器上,运行startup闪退 解决方法: 1.检查发现当前系统没有安装配置jdk,安装配置后运行仍然闪退 2.在tomcat的启动脚本和关闭脚本中指定JDK和to ...

  9. IntelliJ IDEA安装、配置、测试

    IntelliJ IDEA安装.配置.测试(win7_64bit) 目录 1.概述 2.本文用到的工具 3.安装.激活与配置 4.开发测试 4.1 JavaSE开发测试(确保JDK已正确安装) 4.2 ...

  10. 性能优化1--UI优化

    1.使用系统为我们提供了几个抽象的标签 ①include:重用 include中layout属性指定一个外部布局文件,通过该方式则不需要把这个布局文件在该代码中重复的写一遍了. 若include指定了 ...