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. 在linux中关闭防火墙

    1) 重启后生效 开启: chkconfig iptables on 关闭: chkconfig iptables off 2) 即时生效,重启后失效 开启: service iptables sta ...

  2. 【详细】Lucene使用案例

    Lucene是apache软件基金会4 jakarta项目组的一个子项目,是一个开放源代码的全文检索引擎工具包,但它不是一个完整的全文检索引擎,而是一个全文检索引擎的架构,提供了完整的查询引擎和索引引 ...

  3. Gson序列化对象如何忽略字段

    Gson序列化对象如何忽略字段 Gson版本 2.8.2 梗概 用注解@Expose(serialize = false, deserialize = false)在类的成员上以告诉Gson 跳过本字 ...

  4. 第二章 Idea搭建maven

    第二章 Idea搭建maven 1.配置Maven的环境变量 a.首先我们去maven官网下载Maven程序,解压到安装目录,如图所示: b.配置M2_HOME(MAVEN_HOME)的环境变量,然后 ...

  5. Spring Security 入门(1-9)国际化的使用

  6. 记java应用linux服务单个CPU使用率100%分析

    之前在做项目的过程中,项目完成后在linux服务器上做性能测试,当服务跑起来的时候发现cpu使用率很奇怪,java应用把单个cpu跑满了,其他cpu利用率0%. 刚开始遇到这问题的时候我第一时间反应使 ...

  7. NOPI实现导入导出泛型List,支持自定义列

    概述 业务上需要自定义列的Excel的导入导出,在网上看了好多资料,很多都是有Bug而且都是支持Excel和DataTable的转换,所以自己总结了一下,应用.NET平台上的NPOI封装了支持自定义列 ...

  8. Django 学生管理系统

    1. 一对一 班级  模态增加 编辑 def classes(request): data = sqlheper.get_list("select cid,title from class& ...

  9. jupyter notebook的架构

    最近项目需要改写jupyter notebook的内核,由于内功不够,英语过差,读文档真的是心痛,然后各种搜索找到了一篇不错的讲解. 转自:http://blog.just4fun.site/jupy ...

  10. Tumblr:我们是如何从 PHP 5 升级到 PHP 7 的

    Tumblr 团队经常在寻找新的方式来提升网站的性能.这意味着要给访问量大的代码增加缓存,找到更快的 CDN 配置,或者升级基础软件. 最近,通过一次跨团队的努力,我们将全部 web 服务器战舰从 P ...