每个非素数(合数)都可以写成几个素数(也可称为质数)相乘的形式,这几个素数就都叫做这个合数的质因数。比如,6可以被分解为2x3,而24可以被分解为2x2x2x3。
现在,你的程序要读入一个[2,100000]范围内的整数,然后输出它的质因数分解式;当读到的就是素数时,输出它本身。
#include <stdio.h>
int isPrime(int a);
int main()
{
int n;
scanf("%d",&n);
if(isPrime(n)==1){
printf("n=%d",n);
}else{
printf("n=");
for(int i=2;i<n;i++){
if(isPrime(i)==1){
do{
if(n%i==0){
printf("%dx",i);
n /= i;
}
break;
}while(isPrime(n)==0);
}
if(isPrime(n)==1){
printf("%d",n);
break;
}
}
}
return 0;
}
int isPrime(int a)
{
int isPrime;
int i;
for(i=2;i<a;i++){
if(a%i==0){
isPrime=0;
break;
}
}
if(i>=a){
isPrime=1;
}
}