杜教筛--51nod1239 欧拉函数之和
求$\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 欧拉函数之和的更多相关文章
- 【learning】杜教筛求欧拉函数前缀和
我们考虑利用\(\sum\limits_{d|n}\varphi(d)=n\)这一性质来处理这个问题 设\(f(n)=\sum\limits_{i=1}^{n}\varphi(i)\) 那么我们可以得 ...
- 51nod1239 欧拉函数之和
跟1244差不多. //由于(x+1)没有先mod一下一直WA三个点我... //由于(x+1)没有先mod一下一直WA三个点我... #include<cstdio> #include& ...
- [51nod1239] 欧拉函数之和(杜教筛)
题面 传送门 题解 话说--就一个杜教筛--刚才那道拿过来改几行就行了-- //minamoto #include<bits/stdc++.h> #define R register #d ...
- [51nod1239欧拉函数之和]
来自FallDream的博客,未经允许,请勿转载,谢谢 --------------------------------------------- 给定n,求$S(n)=\sum_{i=1}^{n}\ ...
- 51 NOD 1239 欧拉函数之和(杜教筛)
1239 欧拉函数之和 基准时间限制:3 秒 空间限制:131072 KB 分值: 320 难度:7级算法题 收藏 关注 对正整数n,欧拉函数是小于或等于n的数中与n互质的数的数目.此函数以其首名研究 ...
- [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== ...
- 【51nod-1239&1244】欧拉函数之和&莫比乌斯函数之和 杜教筛
题目链接: 1239:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1239 1244:http://www.51nod. ...
- 51nod 1239 欧拉函数之和(杜教筛)
[题目链接] https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1239 [题目大意] 计算欧拉函数的前缀和 [题解] 我们 ...
- 【51nod】1239 欧拉函数之和 杜教筛
[题意]给定n,求Σφ(i),n<=10^10. [算法]杜教筛 [题解] 定义$s(n)=\sum_{i=1}^{n}\varphi(i)$ 杜教筛$\sum_{i=1}^{n}(\varph ...
随机推荐
- 443 String Compression 压缩字符串
给定一组字符,使用原地算法将其压缩.压缩后的长度必须始终小于或等于原数组长度.数组的每个元素应该是长度为1 的字符(不是 int 整数类型).在完成原地修改输入数组后,返回数组的新长度.进阶:你能否仅 ...
- 222 Count Complete Tree Nodes 完全二叉树的节点个数
给出一个完全二叉树,求出该树的节点个数.完全二叉树的定义如下:在完全二叉树中,除了最底层节点可能没填满外,其余每层节点数都达到最大值,并且最下面一层的节点都集中在该层最左边的若干位置.若最底层为第 h ...
- 【Hibernate】Access to DialectResolutionInfo cannot be null when 'hibernate.dialect' not set
今天用hibernate框架写crm项目时遇到报错: Access to DialectResolutionInfo cannot be null when 'hibernate.dialect' n ...
- 建造者模式以及php实现
建造者模式: 造者模式(Builder Pattern):将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示. 建造者模式是一步一步创建一个复杂的对象,它允许用户只通过指定复杂对 ...
- Windows下的一个Nginx 批处理命令行控制台
其实作用很简单,就是为了少输入几个字母,完成对Nginx的控制而已,同时也算是练习了一把bat批处理吧. @echo off&color e&Title Nginx 命令行控制台 cl ...
- oracle 执行跟踪
一.sql_trace的介绍 --打开trace文件设置,把sql trace设置为true,就会在udump目录中增加一个trc文件.alter session set sql_trace=true ...
- CREATE AGGREGATE - 定义一个新的聚集函数
SYNOPSIS CREATE AGGREGATE name ( BASETYPE = input_data_type, SFUNC = sfunc, STYPE = state_data_type ...
- pavenet资源
网络结构:http://www.cnblogs.com/fariver/p/7449563.html 源码:https://github.com/sanghoon/pva-faster-rcnn 训练 ...
- 【传智播客】Libevent学习笔记(一):简介和安装
目录 00. 目录 01. libevent简介 02. Libevent的好处 03. Libevent的安装和测试 04. Libevent成功案例 00. 目录 @ 01. libevent简介 ...
- IIS部署SSL证书后提示不可信的解决方案
IIS部署SSL证书后提示不可信的解决方案 本帖最后由 wosign-support3 于 2015-7-17 17:18 编辑 第一步:打开mmc——点击文件——添加删除管理单元——证书——计算 ...