IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> [复习]杜教筛 -> 正文阅读

[C++知识库][复习]杜教筛

杜教筛的推导过程懒得写了,反正是复习,记个结论吧。

对于我们要筛的积性函数 f f f ,构造一个函数 g g g,记 f ? g = h f*g=h f?g=h

我们的目标是求 f f f 前缀和 s s s

那么有

g ( 1 ) s ( n ) = ∑ i = 1 n h ( i ) ? ∑ i = 2 n g ( i ) s ( ? n i ? ) g(1)s(n)=\sum\limits_{i=1}^nh(i)-\sum\limits_{i=2}^ng(i)s(\lfloor\frac{n}{i} \rfloor) g(1)s(n)=i=1n?h(i)?i=2n?g(i)s(?in??)

睿智的发文助手再次表示我太短了。那就写点常见函数如何构造 g g g 吧。

μ ( i ) \mu(i) μ(i):构造 I ( i ) I(i) I(i) f ? I = e f*I=e f?I=e,前缀和显然非常好求。

μ ( i ) i \mu(i)i μ(i)i:构造 i d ( i ) id(i) id(i),卷积结果是 n ∑ d ∣ n μ ( d ) n \sum_{d|n}\mu(d) ndn?μ(d),后面部分不就是莫反吗,前缀和非常好求。

μ ( i ) i 2 \mu(i)i^2 μ(i)i2:构造 i d ( i ) id(i) id(i),卷积结果是 n 2 ∑ d ∣ n μ ( d ) n^2 \sum_{d|n}\mu(d) n2dn?μ(d),后面部分不就是莫反吗,前缀和非常好求。

? ( i ) \phi(i) ?(i):构造 I I I ? ? I = i d \phi * I=id ??I=id,前缀和非常好求。

睿智的发文助手再次表示我太短了,单调栈镇楼:

#include<bits/stdc++.h>
using namespace std;
int n,q;
const int maxn=2e6+5;
int S[maxn],tp;
int id[maxn];
int a[maxn],b[maxn];
static char buf[1000000],*p1=buf,*p2=buf,obuf[1000000],*p3=obuf;
#define getchar() p1==p2&&(p2=(p1=buf)+fread(buf,1,1000000,stdin),p1==p2)?EOF:*p1++
#define putchar(x) (p3-obuf<1000000)?(*p3++=x):(fwrite(obuf,p3-obuf,1,stdout),p3=obuf,*p3++=x)
template<typename item>
inline void read(register item &x)
{
    x=0;register char c=getchar();
    while(c<'0'||c>'9')c=getchar();
    while(c>='0'&&c<='9')x=(x<<3)+(x<<1)+(c^48),c=getchar();
}
static char cc[10000];
template<typename item>
inline void print(register item x)
{ 
	register long long len=0;
	while(x)cc[len++]=x%10+'0',x/=10;
	while(len--)putchar(cc[len]);
}
struct pt{
	int x,y;
}p[maxn];
int t2=1;
int data[2];
struct BIT{
	int C[maxn];
	#define lowbit(i) i&(-i)
	void add(int x,int k){
		x++;
		while(x<=data[t2]){
			C[x]+=k;
			x+=lowbit(x);	
		}
	}
	int sum(int x){
		x++;
		int ans=0;
		while(x){
			ans+=C[x];
			x-=lowbit(x);
		}
		return ans;
	}
}T;
int ans[maxn];
struct query{
	int x,y,id,k;
}qr[maxn];
bool cmpq(query a,query b){ 
	if(a.y==b.y)return a.x<b.x;
	return a.y<b.y;
}
int qc=0;
int l[maxn],r[maxn];
bool cmp(pt a,pt b){
	if(a.y==b.y)return a.x<b.x;
	return a.y<b.y;
}
int main(){
//	freopen("stack.in","r",stdin);
//	freopen("stack.out","w",stdout);
	read(n);
	read(q);
	for(int i=1;i<=n;i++)read(a[i]);
	for(int i=1;i<=n;i++)read(b[i]);
	data[1]=n+1;
	tp=0;
	for(int i=1;i<=n;i++){
		while(tp&&(a[S[tp]]==a[i]||b[S[tp]]<=b[i]))tp--;
		id[i]=S[tp];
		S[++tp]=i;
		p[i]=(pt){i,id[i]};
//		cout<<i<<" "<<id[i]<<endl;
	}
	for(int i=1;i<=q;i++){ 
		read(l[i]); 
		read(r[i]);
		qr[++qc]=(query){r[i],r[i],i,1};
		qr[++qc]=(query){l[i]-1,l[i]-1,i,1};
		qr[++qc]=(query){l[i]-1,r[i],i,-1};
		qr[++qc]=(query){r[i],l[i]-1,i,-1};
	}
	sort(qr+1,qr+qc+1,cmpq);
	sort(p+1,p+n+1,cmp);
	int now=1;
	for(int i=1;i<=qc;i++){
//		cout<<qr[i].x<<" "<<qr[i].y<<endl;
		while((p[now].y<qr[i].y||(p[now].y==qr[i].y&&p[now].x<=qr[i].x))&&now<=n)T.add(p[now].x,1),now++;
		ans[qr[i].id]+=qr[i].k*T.sum(qr[i].x); 
//		cout<<T.sum(qr[i ].x)<<"!"<<endl;
	}
	for(int i=1;i<=q;i++){
		int res=r[i]-l[i]+1-ans[i];
		if(res)print(res);
		else putchar('0'); 
		putchar('\n');
	}
	fwrite(obuf,p3-obuf,1,stdout);
	return 0;
}
  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-07 22:27:40  更:2022-04-07 22:29:39 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:26:35-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码