题目描述
将一个正整数分解质因数,例如,输入90,输出2 3 3 5。
输入
输入一个正整数n(2<=n<=2000)。
输出
从小到大输出n的所有质因子,每两个数之间空一格。
样例输入 Copy
20
样例输出 Copy
2 2 5
#include<stdio.h>//了解质因子就是因子为质数
#include<stdlib.h>
int main()
{
int i=2,n;
scanf("%d",&n);
while(i*i<n)
{
while(n%i==0)//判断是n的质数,再决定是否满足当的条件
{
printf("%d ",i);
n=n/i;
}
i++;
}
if(n!=1)//防止最后n除完后就剩下一个n=1了 就不满足从最小的质因子输出到最大的质因子了
{
printf("%d",n);
}
return 0;
}