积性函数与线性筛
积性函数与线性筛#
积性函数#
定义#
互质,有 的函数 为积性函数
常见的积性函数#
: 的正因子数目
: 的所有正因子之和
:欧拉函数
:莫比乌斯函数
性质#
可以通过 来线性筛
积性函数的线性筛#
所有积性函数线性筛的基础是线性筛素数
线性筛素数#
inline void get_prime(){
not_p[1]=1;
for(int i=2;i<=N;++i){
if(!not_p[i]) pri[++cnt]=i;
for(int j=1;j<=cnt&&i*pri[j]<=N;++j){
not_p[i*pri[j]]=1;
if(i%pri[j]==0) break;
}
}
}
线性筛欧拉函数 #
inline void get_phi(){
phi[1]=1;
not_p[1]=1;
for(int i=2;i<=N;++i){
if(!not_p[i]){
p[++cnt]=i;
phi[i]=i-1;
}
for(int j=1;j<=cnt&&i*p[j]<=N;++j){
not_p[i*p[j]]=1;
if(i%p[j]==0){
phi[i*p[j]]=phi[i]*p[j];
break;
}
else
phi[i*p[j]]=phi[i]*(p[j]-1);
}
}
}
线性筛莫比乌斯函数 #
inline void get_mu(){
mu[1]=1;
not_p[1]=1;
for(int i=2;i<=N;++i){
if(!not_p[i]){
p[++cnt]=i;
mu[i]=-1;
}
for(int j=1;j<=cnt&&i*p[j]<=N;++j){
not_p[i*p[j]]=1;
if(i%p[j]==0){
mu[i*p[j]]=0;
break;
}
else
mu[i*p[j]]=-mu[i];
}
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现