杜教筛进阶+洲阁筛讲解+SPOJ divcnt3
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的更多相关文章
- 【XSY3042】石像 拓扑排序 状压DP 洲阁筛
题目大意 有 \(n\) 个整数 \(a_1,a_2,\ldots,a_n\),每个数的范围是 \([1,m]\).还有 \(k\) 个限制,每个限制 \(x_i,y_i\) 表示 \(a_{x_i} ...
- 洲阁筛 & min_25筛学习笔记
洲阁筛 给定一个积性函数$F(n)$,求$\sum_{i = 1}^{n}F(n)$.并且$F(n)$满足在素数和素数次幂的时候易于计算. 显然有: $\sum_{i = 1}^{n} F(n) = ...
- 【Learning】积性函数前缀和——洲阁筛(min_25写法)
问题描述 洲阁筛解决的问题主要是\(n\)范围较大的积性函数前缀和. 已知一积性函数\(f(i)\),求\(\sum_{i=1}^nf(i)\). \(n\leq10^{12}\). 求解方法 如 ...
- 【learning】洲阁筛
问题描述 快速求素数处点值比较好求的积性函数前缀和 大致过程 Step1.求出一定范围内的素数处点值之和(\(g\)) Step2.利用上面的\(g\)求出一个\(f\)然后用\(f\)求出前缀和 具 ...
- 模板 - 洲阁筛 + min25筛
好像在某些情况下杜教筛会遇到瓶颈,先看着.暑假学一些和队友交错的知识的同时开这个大坑.
- [NOI2016]循环之美(杜教筛)
首先要求每个数互不相等,故有$x\perp y$. 可以发现$\frac{x}{y}$在$k$进制下为纯循环小数的充要条件为$x\cdot k^{len}\equiv x(mod\ y)$,即$y\p ...
- BZOJ 4805: 欧拉函数求和 杜教筛
https://www.lydsy.com/JudgeOnline/problem.php?id=4805 给出一个数字N,求sigma(phi(i)),1<=i<=N https://b ...
- 【知识总结】线性筛_杜教筛_Min25筛
首先感谢又强又嘴又可爱脸还筋道的国家集训队(Upd: WC2019 进候选队,CTS2019 不幸 rk6 退队)神仙瓜 ( jumpmelon ) 给我讲解这三种筛法~~ 由于博主的鸽子属性,这篇博 ...
- 一些求和式的估算 & 杜教筛时间复杂度证明
本文内容概要: \(A=\sum\limits_{i=1}^n\dfrac1{\sqrt i}=1+\dfrac1{\sqrt2}+\cdots+\dfrac1{\sqrt n}\) \(O(\sqr ...
随机推荐
- Flask 学习 九 用户资料
资料信息 app/models.py class User(UserMixin,db.Model): #...... name = db.Column(db.String(64)) location ...
- Flask学习 一 基本结构
-from flask import Flask +from flask import Flask,render_template -from flask import request -from f ...
- 使用HTML5视频事件示例
<!DOCTYPE html > <html > <head> <title>Video events example</title> &l ...
- 理解Node.js安装及模块化
1.安装Node Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境. Node.js 使用了一个事件驱动.非阻塞式 I/O 的模型,使其轻量又高效. Node.j ...
- Kafka Cached zkVersion [62] not equal to that in zookeeper, skip updating ISR (kafka.cluster.Partition) 问题分析
我司业务Kafka集群是3节点(broker分别为10,20,30),每个Topic 3 Partition,3 Repilication的配置,早上起床突然发现所有Topic的Broker节点都变为 ...
- Vue框架axios请求(类似于ajax请求)
Vue框架axios get请求(类似于ajax请求) 首先介绍下,这个axios请求最明显的地方,通过这个请求进行提交的时候页面不会刷新 <!DOCTYPE html> <html ...
- Docker学习(1)安装
1. Docker简介 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱 ...
- 微信 登录 Scope 参数错误或没有 Scope 权限
//电脑端 扫码授权登录 public static string AuthUrl = "https://open.weixin.qq.com/connect/qrconnect?appid ...
- requests+正则爬取豆瓣图书
#requests+正则爬取豆瓣图书 import requests import re def get_html(url): headers = {'User-Agent':'Mozilla/5.0 ...
- WPF 自定义TreeView控件样式,仿QQ联系人列表
一.前言 TreeView控件在项目中使用比较频繁,普通的TreeView并不能满足我们的需求.因此我们需要滴对TreeView进行改造.下面的内容将介绍仿QQ联系人TreeView样式及TreeVi ...