Part 1:杜教筛进阶
在了解了杜教筛基本应用,如$\sum_{i=1}^n\varphi(i)$的求法后,我们看一些杜教筛较难的应用。
求$\sum_{i=1}^n\varphi(i)*i$
考虑把它与$id$函数狄利克雷卷积后的前缀和。
$$\sum_{i=1}^n\sum_{d|i}\varphi(d)*d*\frac id=\sum_{i=1}^ni^2$$枚举$T=\frac id$,原式化为
$$\sum_{T=1}^nT\sum_{d=1}^{\lfloor\frac nT\rfloor}\varphi(d)*d=\sum_{i=1}^ni^2$$移项,得
$$\sum_{i=1}^n\varphi(i)*i=\sum_{i=1}^ni^2-\sum_{T=2}^nT\sum_{d=1}^{\lfloor\frac nT\rfloor}\varphi(d)*d$$右边的$\sum_{d=1}^{\lfloor\frac nT\rfloor}\varphi(d)*d$递归求就行了。
总结:当遇到一些不好求前缀和的函数时,一般将其与一个易于求前缀和的函数进行狄利克雷卷积,得到另一个易于求前缀和的函数,然后通过简单的数学变换,得到可以递归的式子。
Part 2:洲阁筛讲解
有一篇博客讲的挺好:
http://debug18.com/posts/calculate-the-sum-of-multiplicative-function
Part 3:SPOJ divcnt3

洲阁筛的简单应用。

#include <cstdio>
#include <algorithm>
using namespace std; typedef long long ll;
const int N=316241,p=;
int T,e,tt,t2,pr[N],hd[p],nx[p],w[p],mx[N],ci[N],s[N],D[p];
ll n,a1,to[p],d[p],g[p],f[N],f2[p],sf[N];
void ins(int x,ll y) {int h=y%p; to[++e]=y,w[e]=x,nx[e]=hd[h],hd[h]=e;}
int qr(ll x) {for(int i=hd[x%p];i;i=nx[i]) if(to[i]==x) return w[i]; return ;} void sol() {
e=t2=;
for(ll i=;i<=n;i=n/(n/i)+) hd[n/i%p]=;
for(ll i=;i<=n;i=n/(n/i)+) ins(++t2,n/i),d[t2]=g[t2]=n/i,D[t2]=;
for(int i=;i<=tt;i++)
for(int j=;j<=t2&&(ll)pr[i]*pr[i]<=d[j];j++) {
int k=qr(d[j]/pr[i]); g[j]-=g[k]-(i--D[k]),D[j]=i;
}
}
void sol2() {
for(int i=;i<=t2;i++) f2[t2]=;
for(int i=tt;i;i--)
for(int j=;j<=t2&&(ll)pr[i]*pr[i]<=d[j];j++) {
if(pr[i+]>d[j]) f2[j]=;
else if((ll)pr[i+]*pr[i+]>d[j]) f2[j]=(s[min(N-1LL,d[j])]-s[pr[i+]-])*+;
for(ll pi=pr[i],c=;d[j]>=pi;pi*=pr[i],c++) {
ll k=d[j]/pi,k2;
if(pr[i+]>k) k2=;
else if((ll)pr[i+]*pr[i+]>k) k2=(s[min(N-1LL,k)]-s[pr[i+]-])*+;
else k2=f2[qr(k)];
f2[j]+=k2*(*c+);
}
}
} int main() {
scanf("%d",&T),f[]=sf[]=;
for(int i=;i<N;i++) {
s[i]=s[i-]+!f[i];
if(!f[i]) pr[++tt]=i,f[i]=,mx[i]=i,ci[i]=;
for(int j=,k;j<=tt&&(k=i*pr[j])<N;j++) {
if(i%pr[j]) f[k]=f[i]*,mx[k]=pr[j],ci[k]=;
else {f[k]=f[i/mx[i]]*(ci[i]*+),mx[k]=mx[i]*pr[j],ci[k]=ci[i]+; break;}
}
sf[i]=sf[i-]+f[i];
}
pr[tt+]=;
while(T--) {
scanf("%lld",&n);
if(n<N) {printf("%lld\n",sf[n]); continue;}
a1=,sol(),sol2();
for(int i=,r;i<N;i=r+) {
int j=qr(n/i); ll k;
if(pr[tt+]>n/i) k=;
else k=g[j]-(tt-D[j]);
a1+=(sf[r=min(N-1LL,n/(n/i))]-sf[i-])*(k-)*;
}
printf("%lld\n",a1+f2[]);
}
return ;
}

杜教筛进阶+洲阁筛讲解+SPOJ divcnt3的更多相关文章

  1. 【XSY3042】石像 拓扑排序 状压DP 洲阁筛

    题目大意 有 \(n\) 个整数 \(a_1,a_2,\ldots,a_n\),每个数的范围是 \([1,m]\).还有 \(k\) 个限制,每个限制 \(x_i,y_i\) 表示 \(a_{x_i} ...

  2. 洲阁筛 & min_25筛学习笔记

    洲阁筛 给定一个积性函数$F(n)$,求$\sum_{i = 1}^{n}F(n)$.并且$F(n)$满足在素数和素数次幂的时候易于计算. 显然有: $\sum_{i = 1}^{n} F(n) = ...

  3. 【Learning】积性函数前缀和——洲阁筛(min_25写法)

    问题描述 洲阁筛解决的问题主要是\(n\)范围较大的积性函数前缀和. ​ 已知一积性函数\(f(i)\),求\(\sum_{i=1}^nf(i)\). \(n\leq10^{12}\). 求解方法 如 ...

  4. 【learning】洲阁筛

    问题描述 快速求素数处点值比较好求的积性函数前缀和 大致过程 Step1.求出一定范围内的素数处点值之和(\(g\)) Step2.利用上面的\(g\)求出一个\(f\)然后用\(f\)求出前缀和 具 ...

  5. 模板 - 洲阁筛 + min25筛

    好像在某些情况下杜教筛会遇到瓶颈,先看着.暑假学一些和队友交错的知识的同时开这个大坑.

  6. [NOI2016]循环之美(杜教筛)

    首先要求每个数互不相等,故有$x\perp y$. 可以发现$\frac{x}{y}$在$k$进制下为纯循环小数的充要条件为$x\cdot k^{len}\equiv x(mod\ y)$,即$y\p ...

  7. BZOJ 4805: 欧拉函数求和 杜教筛

    https://www.lydsy.com/JudgeOnline/problem.php?id=4805 给出一个数字N,求sigma(phi(i)),1<=i<=N https://b ...

  8. 【知识总结】线性筛_杜教筛_Min25筛

    首先感谢又强又嘴又可爱脸还筋道的国家集训队(Upd: WC2019 进候选队,CTS2019 不幸 rk6 退队)神仙瓜 ( jumpmelon ) 给我讲解这三种筛法~~ 由于博主的鸽子属性,这篇博 ...

  9. 一些求和式的估算 & 杜教筛时间复杂度证明

    本文内容概要: \(A=\sum\limits_{i=1}^n\dfrac1{\sqrt i}=1+\dfrac1{\sqrt2}+\cdots+\dfrac1{\sqrt n}\) \(O(\sqr ...

随机推荐

  1. 关于collectionView和tableView的两种cell的出列方法的区别

    相信好多人一定会对collectionView和tableView的两种cell出列方法有所疑问,下面以UICollection为例子进行举例说明 假设我们已经创建了一个collectionView, ...

  2. 《高级软件测试》11.14.安装和运行Jira

    今日任务完成情况如下: 小段:研究Jira在Linux的安装教程 小费:尝试在Ubuntu下安装Jira 小高:查阅了关于Jira软件的介绍和安装教程,下载准备明天安装,并学习使用 小王:注册Jira ...

  3. HAOI 2012 高速公路

    https://www.luogu.org/problem/show?pid=2221 题目描述 Y901高速公路是一条重要的交通纽带,政府部门建设初期的投入以及使用期间的养护费用都不低,因此政府在这 ...

  4. PHP常用函数集合

    PHP常用函数总结 数学函数 1.abs(): 求绝对值 $abs = abs(-4.2); //4.2 数字绝对值数字 2.ceil(): 进一法取整 echo ceil(9.999); // 10 ...

  5. Docker学习笔记 - Docker的基本概念

    一.cs架构 Docker客户端:本地或远程 Docker服务端:守护进程Docker Daemon 二.基本概念 Docker镜像:打包阶段,层叠的只读文件系统,引导->root(ubuntu ...

  6. Docker学习笔记 - Docker的守护进程

    学习目标:  查看Docker守护进程的运行状态 启动.停止.重启Docker守护进程 Docker守护进程的启动选项 修改和查看Docker守护进程的启动选项 1.# 查看docker运行状态  方 ...

  7. copy代码(含static对象)留下的致命错误

    本来以为这个bug快改不好了,然而发现了问题所在 copy代码没有完全改掉对象名称,导致对象重复创建了,由于是static所以debug过程中 注释了addProperty(gridRowDetail ...

  8. Python系列-python函数

    函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代码的重复利用率.你已经知道Python提供了许多内建函数,比如print().但你也可以自己创建函数,这 ...

  9. 个人网站建设(适合Java初学者)(一)

    概述 作为一个在八本学校在校生,没有实验室,也没有项目可做.一直想做一个个人博客,一年前学完javaweb之后做了一个简单的博客,ui惨不忍睹就算了,还有各种bug.酝酿了很久,寒假用了将近一个月时间 ...

  10. 使用SQL语句在SQL server2017上创建数据库

    软件基础:在电脑上提前安装好SQL server2017,并且安装好其中的SSMS(SQL server Management Studio) 创建方式:SQL语句 操作内容:创建零件供应数据库系统 ...