min_25筛学习笔记【待填坑】
看见ntf和pb两位大佬都来学了,然后就不自觉的来学了。
我们考虑这样一个问题。
$$ans=\sum_{i=1}^nf(i)$$其中$1\leq n\leq 10^{10}$
其中$f(i)$是一个非常奇怪的函数,并不像$\mu(i),\varphi(i),i\varphi(i)$那样具有那么好的性质。但是满足以下条件:
1.若$p$为质数,则$f(p)$是一个关于$p$的多项式,比如$\mu(p)=-1,\varphi(p)=p-1$.
2.若$p$为质数,$e$为正整数,则$f(p^e)$可以很快求出。(通常是$O(1)$)
3.$f(n)$为积性函数。
然后就可以使用min_25筛了。(顾名思义是min_25发明的)
首先,我们需要知道min_25筛是埃氏筛的一个拓展,它的思想很大一部分借助于埃氏筛。
回想一下埃氏筛,我们是每次将最小质因子为$p_i$的合数筛去,剩下的就是质数。
我们知道这些最小质因子至多为$\sqrt{n}$,所以合数可以通过枚举最小质因子来计算,质数我们则使用另外的方法。
首先我们看质数的怎么做。
$$\sum_{i=1}^n[i\in Prime]f(i)$$
根据条件1,我们知道$f(i)$是一个多项式,这样的话我们可以按照次数将$f(i)$拆成$i^k$之和,因为$i^k$是一个完全积性函数(很快就有用的)。
$$\sum_{i=1}^n[i\in Prime]i^k$$
为了计算这个,我们需要引入一个辅助数组$g(n,j)$。(鬼知道是怎么想到的)
$$g(n,j)=\sum_{i=1}^n[i\in Prime \ or \ minp(i)>P_j]i^k$$
其中$minp(i)$表示$i$的最小质因子,所以
$$\sum_{i=1}^n[i\in Prime]i^k=g(n,|P|)$$
既然我们要使用质数,所以我们可以先用欧拉筛把所有$\leq \sqrt{n}$的质数筛出来,同时还要预处理$\sum_{i=1}^j[i\in Prime]i^k$.
我们考虑dp计算。既然是埃氏筛,我们就要在$g(n,j-1)$中最小质因子为$P_j$的合数筛去。]'
对于$P_j\geq \sqrt{n}$的就不用管它了,因为肯定不可能。
首先,由于它是完全积性函数,所以$P_j$可以直接提出来,剩下的减去$i\leq \lfloor\frac{n}{P_j}\rfloor$中的数就可以了。
这些数中要求质因子$\geq P_j$,所以是$g(\lfloor\frac{n}{P_j}\rfloor,j-1)$,但是这里面质数被重复计算了,所以要减去里面的质数。
$$g(n,j)=g(n,j-1)-P_j^k(g(\lfloor\frac{n}{P_j}\rfloor,j-1)-\sum_{i=1}^{j-1}[i\in Prime]i^k)$$
但是这样的话是$O(n*|P|)$的,时间和空间都承受不了。但是我们发现我们可以使用一个优化。
我们发现$g(n,j)$中$n$只有$O(\sqrt{n})$种取值,因为每次递归的时候是$n$变为$\lfloor\frac{n}{P_j}\rfloor$,而我们发现
$$\lfloor\frac{\lfloor\frac{a}{b}\rfloor}{c}\rfloor=\lfloor\frac{a}{bc}\rfloor$$
所以$n$只会变为$\lfloor\frac{n}{x}\rfloor$,于是我们就直接“手动”离散化,这个可以看代码。
然后$g(n,j)$的第二维也可以滚动数组滚掉。所以时间$O(\sqrt{n}*|P|)$,空间$O(\sqrt{n})$.
预处理部分终于结束了,接下来我们考虑计算答案,首先我们还是需要一个辅助数组。
$$S(n,j)=\sum_{i=1}^n[minp(i)>P_j]f(i)$$
像上面说的一样,分质数和合数两类计算。
$$S(x,y)=g(x,|P|)-\sum_{i=1}^{y}f(P_i)+\sum_{P_k\leq \sqrt{x},k>j}\sum_{e>0,P_k^e\leq x}f(p_k^e)(S(\lfloor\frac{x}{P_k^e}\rfloor,k)+[e>1])$$
前面两项指的是质数,后面的和式是枚举最小质因子$P_k$和它的次数$e$,
这个跟$g$不同,$S$是要按照第二维倒着计算的,但是我们也可以使用递归的方法来计算。
$S(n,0)+f(1)$就是最终答案。
至于上面说的那个手动离散化,我们要开两个数组$id1$和$id2$,分别记录$\leq \sqrt{n}$和$>\sqrt{n}$的部分的数值的编号。这样就不用map了,可以省掉一个log。
至于时间复杂度?我也不知道,总之跟杜教筛差不多,甚至有时候比杜教筛还要快。
#include<bits/stdc++.h>
#define Rint register LL
using namespace std;
typedef long long LL;
const int N = , mod = 1e9 + , inv2 = , inv3 = ;
LL n, Sqr, pri[N], tot, pre1[N], pre2[N], ind1[N], ind2[N], g1[N], g2[N], w[N], cnt;
bool notp[N];
inline void init(LL m){
notp[] = notp[] = true;
for(Rint i = ;i <= m;i ++){
if(!notp[i]){
pri[++ tot] = i;
pre1[tot] = (pre1[tot - ] + i) % mod;
pre2[tot] = (pre2[tot - ] + i * i) % mod;
}
for(Rint j = ;j <= tot && i * pri[j] <= m;j ++){
notp[i * pri[j]] = true;
if(!(i % pri[j])) break;
}
}
}
inline LL S(LL x, int y){
if(pri[y] >= x) return ;
LL k = (x <= Sqr) ? ind1[x] : ind2[n / x];
LL ans = (g2[k] - g1[k] + pre1[y] - pre2[y] + mod + mod) % mod;
for(Rint i = y + ;i <= tot && pri[i] * pri[i] <= x;i ++){
LL pe = pri[i];
for(Rint e = ;pe <= x;e ++, pe *= pri[i]){
LL xx = pe % mod;
ans = (ans + xx * (xx - ) % mod * (S(x / pe, i) + (e > ))) % mod;
}
}
return ans % mod;
}
int main(){
scanf("%lld", &n);
Sqr = sqrt(n);
init(Sqr);
for(Rint i = , last;i <= n;i = last + ){
last = n / (n / i);
w[++ cnt] = n / i;
LL xx = w[cnt] % mod;
g1[cnt] = (xx * (xx + ) / + mod - ) % mod;
g2[cnt] = (xx * (xx + ) / % mod * ( * xx + ) % mod * inv3 % mod + mod - ) % mod;
if(n / i <= Sqr) ind1[w[cnt]] = cnt;
else ind2[last] = cnt;
}
for(Rint i = ;i <= tot;i ++)
for(Rint j = ;j <= cnt && pri[i] * pri[i] <= w[j];j ++){
LL k = (w[j] / pri[i] <= Sqr) ? ind1[w[j] / pri[i]] : ind2[n / (w[j] / pri[i])];
g1[j] -= pri[i] * (g1[k] - pre1[i - ] + mod) % mod;
g2[j] -= pri[i] * pri[i] % mod * (g2[k] - pre2[i - ] + mod) % mod;
if(g1[j] < ) g1[j] += mod;
if(g2[j] < ) g2[j] += mod;
}
printf("%lld", (S(n, ) + ) % mod);
}
luogu5325
练习题:
min_25筛学习笔记【待填坑】的更多相关文章
- Min_25筛 学习笔记
这儿只是一个简单说明/概括/总结. 原理见这: https://www.cnblogs.com/cjyyb/p/9185093.html https://www.cnblogs.com/zhoushu ...
- Min_25 筛 学习笔记
原文链接https://www.cnblogs.com/zhouzhendong/p/Min-25.html 前置技能 埃氏筛法 整除分块(这里有提到) 本文概要 1. 问题模型 2. Min_25 ...
- 洲阁筛 & min_25筛学习笔记
洲阁筛 给定一个积性函数$F(n)$,求$\sum_{i = 1}^{n}F(n)$.并且$F(n)$满足在素数和素数次幂的时候易于计算. 显然有: $\sum_{i = 1}^{n} F(n) = ...
- Min_25筛学习笔记
感觉好好用啊 Luogu上的杜教筛模版题一发 Min_25抢到了 rank1 $ Updated \ on 11.29 $被 STO txc ORZ踩爆啦 前言 $ Min$_$25$筛可以求积性函数 ...
- $Min\_25$筛学习笔记
\(Min\_25\)筛学习笔记 这种神仙东西不写点东西一下就忘了QAQ 资料和代码出处 资料2 资料3 打死我也不承认参考了yyb的 \(Min\_25\)筛可以干嘛?下文中未特殊说明\(P\)均指 ...
- Powerful Number 筛学习笔记
Powerful Number 筛学习笔记 用途 \(Powerful\ number\) 筛可以用来求出一类积性函数的前缀和,最快可以达到根号复杂度. 实现 \(Powerful\ number\) ...
- (目录)Fortran学习笔记:开坑!!!
前言:因为某些原因,需要使用Fortran编写程序,记录下Fortran语法学习过程中的部分笔记.在此开坑记录,立下Flag,"希望年末能够更新完" Fortran 学习笔记 陈橙 ...
- Min_25筛 学习小记
前言 为什么叫学习小记呢?因为暂时除了模板题就没有做其他的东西了.(雾 这个东西折磨了我一整天,看得我身不如死,只好结合代码理解题解,差点死在机房.(话说半天综合半天竞赛真是害人不浅) 为了以后忘了再 ...
- min-25筛学习笔记
Min_25筛简介 \(\text{min_25}\)筛是一种处理一类积性函数前缀和的算法. 其中这类函数\(f(x)\)要满足\(\sum_{i=1}^{n}[i\in prime]\cdot f( ...
随机推荐
- jira索引失败
""" # 参考:http://www.mamicode.com/info-detail-2369087.html jira断电重启后索引失败, 解决方法: 关闭jira ...
- sqlserver时间戳
SELECT DATEADD(S,1576464113 + 8 * 3600,'1970-01-01 00:00:00') --时间戳转换成普通时间 SELECT DATEDIFF(S,'1970-0 ...
- (五)Hibernate的增删改查操作(2)
接上一章节 HQL的预编译语句 HIbernate中的预编译与Spring的预编译的处理差不多. 1:使用标准的? 2:使用命名参数 2.1:使用名称逐个设置. 2.2:使用Map(k ...
- IOC实现-Unity
.NET中实现IOC有很多方式,比如:Unity.Ninject.Autofac.MEFNinject的实现参考<Pro ASP.NET MVC3.5 FrameWork>下面给出的是Un ...
- 关于微信小程序获取view的动态高度填坑
wx.createSelectorQuery().select('#box').boundingClientRect(function (rect) { width = rect.width heig ...
- vue-filters(过滤器)
局部过滤器: <html> <head> <title>vue</title> <meta charset="utf-8"&g ...
- Masonry个人笔记
1.有些场合需要获取View在约束之后的frame.直接init初始化后取出来的均为(0,0,0,0).在以下方法中获取即可: View: - (void)layoutSubviews ViewCon ...
- 【Distributed】分布式配置中心
一.概述 1.1 什么是分布式配置中心 常用分布式配置中心框架 二.Apollo阿波罗 2.1 Apollo特点 2.2 Apollo整体架构原理 2.3 Apollo Portol 环境搭建 Lin ...
- InnoDB全文索引
### 如果想了解全文索引,可以直接将本文复制到mysql的新建查询中,依次执行,即可了解全文索引的相关内容及特性. -- InnoDB全文索引 -- 建表 CREATE TABLE fts_a ( ...
- Image Processing and Analysis_15_Image Registration:HAIRIS: A Method for Automatic Image Registration Through Histogram-Based Image Segmentation——2011
此主要讨论图像处理与分析.虽然计算机视觉部分的有些内容比如特 征提取等也可以归结到图像分析中来,但鉴于它们与计算机视觉的紧密联系,以 及它们的出处,没有把它们纳入到图像处理与分析中来.同样,这里面也有 ...