求$\sum_{i=1}^{n}\varphi (i)$,$n\leqslant 1e10$。

这里先把杜教筛的一般套路贴一下:

要求$S(n)=\sum_{i=1}^{n}f(i)$,而现在有一数论函数$g(i)$,$g(i)$的前缀和很无脑,且$f$和$g$的狄利克雷卷积的前缀和很无脑(太巧了吧。。),那么由

$\sum_{i=1}^{n}\sum_{d|i}f(d)g(\frac{i}{d})$

闪一句,常用套路:设$i=kd$,转而枚举$k$。

$=\sum_{k=1}^{n}g(k)\sum_{d=1}^{\left \lfloor \frac{n}{k} \right \rfloor}f(d)$

$=\sum_{k=1}^{n}g(k)S(\frac{n}{k})$

可得

$g(1)S(n)=\sum_{i=1}^{n}\sum_{d|i}f(d)g(\frac{i}{d})-\sum_{k=2}^{n}g(k)S(\left \lfloor \frac{n}{k} \right \rfloor)$

进而递推求S。

官方复杂度:(假如构造的卷积的前缀和和g的前缀和都是O(1)可知)由于S那个除法的取值范围:1,2,……,m-1,m,n/m,n/(m-1),……,n,

可以想到预处理一部分再算一部分,假设预处理了$n^k$,那么总的复杂度就是:$max(n^k,没预处理的那一段)$,

没预处理的那段就是$\sum_{i=1}^{n^{1-k}}\sqrt{\frac{n}{i}}=n^{\frac{1}{2}}\sum_{i=1}^{n^{1-k}}i^{-\frac{1}{2}}\approx n^{\frac{1}{2}}n^\frac{1-k}{2}$

所以总的复杂度就是$max(n^k,n^{\frac{1}{2}}n^\frac{1-k}{2})$,当$\frac{1}{2}+\frac{1-k}{2}=k$时取得最小复杂度,$k=\frac{2}{3}$.

然而我这里有点不懂:因为没预处理的那段我们是直接递归+记忆化的,那记忆化的那部分复杂度怎么算?如何证明杜教筛过程中出现的数字个数的上限?暂不知。先用着。

好那这道题,我们要找一个前缀和无脑且和$\varphi $乘起来无脑的一个函数--1!——就是f(x)=1不知道叫什么——因为有$\varphi *1=Id$,$Id(x)=x$。

那就带进去玩一玩:

$\sum_{i=1}^{n}\sum_{d|i}\varphi (d)=\sum_{k=1}^{n}1\sum_{d=1}^{\left \lfloor \frac{n}{k} \right \rfloor}\varphi (d)= \sum_{k=1}^{n}S(\left \lfloor \frac{n}{k} \right \rfloor)$

玩够一百下再玩一百下:

$S(n)=\sum_{i=1}^{n}\sum_{d|i}1*\varphi (d)-\sum_{k=2}^{n}S(\left \lfloor \frac{n}{k} \right \rfloor)=\frac{n(n+1)}{2}-\sum_{k=2}^{n}S(\left \lfloor \frac{n}{k} \right \rfloor)$。

OK丢去筛吧。

 #include<string.h>
#include<stdlib.h>
#include<stdio.h>
#include<math.h>
//#include<assert.h>
#include<algorithm>
//#include<iostream>
//#include<bitset>
using namespace std; #define LL long long
LL n,m;
#define maxn 5000011
const int mod=1e9+;
int phi[maxn],sumphi[maxn],prime[maxn/],lp; bool notprime[maxn];
void pre(int n)
{
lp=; phi[]=; sumphi[]=;
for (int i=;i<=n;i++)
{
if (!notprime[i]) {prime[++lp]=i; phi[i]=i-;}
sumphi[i]=sumphi[i-]+phi[i];
sumphi[i]-=sumphi[i]>=mod?mod:;
for (int j=,tmp;j<=lp && 1ll*prime[j]*i<=n;j++)
{
notprime[tmp=i*prime[j]]=;
if (i%prime[j]) phi[tmp]=1ll*phi[i]*(prime[j]-)%mod;
else {phi[tmp]=1ll*phi[i]*prime[j]%mod; break;}
}
}
} struct Edge{LL to; int v,next;};
#define maxh 1000007
struct Hash
{
int first[maxh],le;Edge edge[maxn];
Hash() {le=;}
void insert(LL y,int v)
{int x=y%maxh; Edge &e=edge[le]; e.to=y; e.v=v; e.next=first[x]; first[x]=le++;}
int find(LL y)
{
int x=y%maxh;
for (int i=first[x];i;i=edge[i].next) if (edge[i].to==y) return edge[i].v;
return -;
}
}h; int du(LL n)
{
if (n<=m) return sumphi[n];
int tmp=h.find(n); if (tmp!=-) return tmp;
LL tot=;
for (LL i=,last;i<=n;i=last+)
{
last=n/(n/i);
tot+=(last-i+)*du(n/i)%mod;
tot-=tot>=mod?mod:;
}
LL ans=(n%mod)*((n+)%mod)%mod*((mod+)>>)%mod-tot;
ans+=ans<?mod:;
h.insert(n,ans);
return ans;
} int main()
{
scanf("%lld",&n);
m=(LL)pow(pow(n,1.0/),); pre(m);
printf("%d\n",du(n));
return ;
}

杜教筛--51nod1239 欧拉函数之和的更多相关文章

  1. 【learning】杜教筛求欧拉函数前缀和

    我们考虑利用\(\sum\limits_{d|n}\varphi(d)=n\)这一性质来处理这个问题 设\(f(n)=\sum\limits_{i=1}^{n}\varphi(i)\) 那么我们可以得 ...

  2. 51nod1239 欧拉函数之和

    跟1244差不多. //由于(x+1)没有先mod一下一直WA三个点我... //由于(x+1)没有先mod一下一直WA三个点我... #include<cstdio> #include& ...

  3. [51nod1239] 欧拉函数之和(杜教筛)

    题面 传送门 题解 话说--就一个杜教筛--刚才那道拿过来改几行就行了-- //minamoto #include<bits/stdc++.h> #define R register #d ...

  4. [51nod1239欧拉函数之和]

    来自FallDream的博客,未经允许,请勿转载,谢谢 --------------------------------------------- 给定n,求$S(n)=\sum_{i=1}^{n}\ ...

  5. 51 NOD 1239 欧拉函数之和(杜教筛)

    1239 欧拉函数之和 基准时间限制:3 秒 空间限制:131072 KB 分值: 320 难度:7级算法题 收藏 关注 对正整数n,欧拉函数是小于或等于n的数中与n互质的数的数目.此函数以其首名研究 ...

  6. [51Nod 1244] - 莫比乌斯函数之和 & [51Nod 1239] - 欧拉函数之和 (杜教筛板题)

    [51Nod 1244] - 莫比乌斯函数之和 求∑i=1Nμ(i)\sum_{i=1}^Nμ(i)∑i=1N​μ(i) 开推 ∑d∣nμ(d)=[n==1]\sum_{d|n}\mu(d)=[n== ...

  7. 【51nod-1239&1244】欧拉函数之和&莫比乌斯函数之和 杜教筛

    题目链接: 1239:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1239 1244:http://www.51nod. ...

  8. 51nod 1239 欧拉函数之和(杜教筛)

    [题目链接] https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1239 [题目大意] 计算欧拉函数的前缀和 [题解] 我们 ...

  9. 【51nod】1239 欧拉函数之和 杜教筛

    [题意]给定n,求Σφ(i),n<=10^10. [算法]杜教筛 [题解] 定义$s(n)=\sum_{i=1}^{n}\varphi(i)$ 杜教筛$\sum_{i=1}^{n}(\varph ...

随机推荐

  1. 转 Docker Swarm vs Kubernetes

    容器化已经改变我们部署软件和微服务开发的方式.如果你刚听说容器, 这篇博客帮你入门. 什么是容器编排 容器能够把服务打包成基本单元,你可以把它部署到任何地方:本地机器.测试环境或者生产系统.但是在生产 ...

  2. 工作记录 angular页面操作 MD5加密

    今天只是做页面,基于angularjs,有美工做的图打底,确实好用 密码保存,用到了C# MD5加密: https://www.cnblogs.com/healer007/p/5062189.html

  3. vue-webpack所构建好的项目中增加Eslint

    首先在package.json中配置eslint模块: 在终端运行命令:npm install 然后在build文件夹中web pack.base.conf.js配置eslint 接下来在在项目中新建 ...

  4. spark源码学习-withScope

     withScope是最近的发现版中新增加的一个模块,它是用来做DAG可视化的(DAG visualization on SparkUI) 以前的sparkUI中只有stage的执行情况,也就是说我们 ...

  5. R in action读书笔记(4)-第六章:基本图形(下)

    6.3直方图 hist() 其中的x是一个由数据值组成的数值向量.参数freq=FALSE表示根据概率密度而不是频数绘制图形.参数breaks用于控制组的数量.在定义直方图中的单元时,默认将生成等距切 ...

  6. wps 图片代码 复制 粘贴

    <table><tr><td><img src="C:\Users\Administrator\Desktop\QQ截图20160921180946 ...

  7. IE主页被恶意修改处理办法

    HKEY_USERS/.DEFAULT/Software/Policies/Microsoft/Internet Explorer/Control Panel 下的DWORD值“homepage”的键 ...

  8. KMS

    slmgr -ipk 73KQT-CD9G6-K7TQG-66MRP-CQ22C

  9. 5-Java-C(小题答案)

    1. a[i][j]=a[i-1][j-1]+a[i-1][j] 2.1835421 3.93 4.1572836

  10. CAD参数绘制半径标注(网页版)

    主要用到函数说明: _DMxDrawX::DrawDimRadial 绘制一个半径标注.详细说明如下: 参数 说明 DOUBLE dCenterX 被标注的曲线的中点X值 DOUBLE dCenter ...