只要找到p除1和本身外的两个质因素1就一定赢
#include<stdio.h>
#include<math.h>
int check(__int64 n)
{
__int64 i,k;
for(i=2;i<=sqrt(n);i++)
{
if(n%i==0)
return 0;
}
return 1;
}
int main()
{
__int64 q;
__int64 i,sum,k;
scanf("%I64d",&q);
sum=1;
k=1;
for(i=2;i<=sqrt(q);i++)
{
if(q%i==0&&check(i))
{
//printf("W%d
",i);
sum++;
if(i*i<q&&q%(i*i)==0)//注意当i的平方也是q的因数时i可以当两个质数用
{
printf("1
%I64d
",i*i);
return 0;
}
k*=i;
if(sum>=3)
{
printf("1
%I64d
",k);
return 0;
}
}
}
if(sum==1)
printf("1
0
");
else
printf("2
");
return 0;
}