社区讨论

全RE求助

P3383【模板】线性筛素数参与者 2已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@mdvcw3ou
此快照首次捕获于
2025/08/03 15:24
7 个月前
此快照最后确认于
2025/08/03 20:17
7 个月前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
vector<int>w;
bool b[100000001];
int a[600001],o,n,q;
void f(int n){
	a[1]=1;
	for(int i=2;i<=n;i++){
		if(!b[i]){
			w.push_back(i);
			a[i]=i-1;
		}
		for(int j:w){
			if(i*j>n)break;
			b[i*j]=true;
			if(i%j==0){
				a[i*j]=a[i]*j;
				break;
			}
			a[i*j]=a[i]*a[j];
		}
	}
	return;
}
int main(){
	std::ios::sync_with_stdio(0);
	cin.tie(0);
	cin>>n>>q;
	f(n);
	while(q--){
		cin>>o;
		cout<<w[o-1]<<"\n";
	}
}

回复

2 条回复,欢迎继续交流。

正在加载回复...