求一个数的质因子用到的方法就是有策略的暴力,没求出一个质因子,就让原数消除这一个因数。
//求一个数的质因子
#include <stdio.h>
int main()
{
__int64 a[100],num,i,n;
while(scanf("%I64d",&n)!=EOF)
{
num=0;
for(i=2;i*i<=n;i++)
{
if(n%i==0)
{
a[num++]=i;
while(n%i==0)
n=n/i;
}
}
if(n>1)
a[num++]=n;
for(i=0;i<num;i++)
printf("%I64d ",a[i]);
printf("\n");
}
return 0;
}
寻找数的质因子:高效算法详解
189

被折叠的 条评论
为什么被折叠?



