社区讨论

MLE,求指教

P1075[NOIP 2012 普及组] 质因数分解参与者 5已保存回复 7

讨论操作

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

当前回复
7 条
当前快照
1 份
快照标识符
@m0g19x2t
此快照首次捕获于
2024/08/30 09:26
2 年前
此快照最后确认于
2025/11/04 22:03
4 个月前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
void ola(int n,long long o[]);
void ola(int n,long long o[])
{
	o[1]=0;
	for(int i=1;i<=n;i++)
	{
		if(o[i]==-1)
		{
			bool flag=1;
			for(int j=2;j<=n-1;j++)
				if(i%j==0)flag=1;
			if(flag)o[i]=1;
			else o[i]=0;
			for(int x=2;x*i<=n;x++)
				o[x*i]=0;
		}
	}
	
}
int main()
{
	int n,ans;
	cin>>n;
	long long o[n+3];
	memset(o,-1,sizeof(o));
	ola(n,o);
	for(int i=1;i<=n/2;i++)
	{
		if(n%i==0&&o[i]==1)
			ans=i;
	}
	cout<<ans;
}
注:ola()是欧拉筛(埃氏筛)

回复

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

正在加载回复...