标签:任务 输出 质因数 分解质因数 for print 格式 nbsp namespace
一个数如果是另一个整数的完全平方,那么我们就称这个数为完全平方数(Pefect Sqaure),也称平方数。
小A认为所有的平方数都是很perfect的~
于是他给了小B一个任务:用任意个不大于n的不同的正整数相乘得到完全平方数,并且小A希望这个平方数越大越好。
请你帮助小B告诉小A满足题意的最大的完全平方数。
样例1 7 样例2 9
样例1 144 样例2 5184
先上代码。
#include<bits/stdc++.h>
using namespace std;
const int mod=100000007;
int a[5000001],n,s;
long long prime[50000001],m;
bool pg[5000001];
void init()
{
cin>>n;
}
void prepare()
{
pg[1]=1;
pg[2]=0;
for(int i=2;i<=n/2+1;i++)
{
if(!pg[i])
{
prime[++s]=1;
a[s]=0;
for(int j=1;j*i<=n;j++)
{
int ll=j;
a[s]++;
while (ll%i==0)
{
a[s]++;
ll/=i;
}
pg[j*i]=1;
}
if (a[s]%2==1) a[s]--;
// cout<<i<<" "<<a[s]<<"\n";
for(int j=1;j<=a[s];j++)
{
prime[s]*=i;
if(prime[s]>20000) prime[s]=prime[s]%mod;
}
}
}
}
void doit()
{
m=1;
for(int i=1;i<=s;i++)
{
m*=prime[i];
if(m>10000)
{
m=m%mod;
}
}
}
void print()
{
cout<<m;
}
int main()
{
init();
prepare();
doit();
print();
}
解析:本题比较好想,方法:将n!分解质因数后将奇数的质因子个数减一,再将所有质因子乘起来取余即可。
优化:
1、筛素数时,搜到一半就可以停了,后面的质数不可能因子数超过一个。
2、快速幂(这里没加),多乘几次再取模。
证明:
奇个数的的质因数一定可去,且留着也没用。
标签:任务 输出 质因数 分解质因数 for print 格式 nbsp namespace
原文地址:http://www.cnblogs.com/Yeswego/p/6363298.html