C语言编程题——分解质因数。。帮忙改正一下。。

每个非素数(合数)都可以写成几个素数(也可称为质数)相乘的形式,这几个素数就都叫做这个合数的质因数。比如,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;
}
}

//#include "stdafx.h"//vc++6.0加上这一行.
#include "stdio.h"
int prime(int n){
    int i;
    if(n>2 && !(n&1) || n<2)return 0;
    for(i=3; i*i<=n;i+=2)
        if(!(n%i)) return 0;
    return 1;
}
int main(void){
    int nDec,i,n=2;
    while(1){
        printf("Type n(1<n<=100000)...\nn=");
        if(scanf("%d",&nDec),nDec>1 && nDec<100001)
            break;
        printf("Error, redo: ");
    }
    printf("%d = ",nDec);
    while(nDec>1 && !prime(nDec))
        for(i=n;;i==2 ? i++ : i+=2)
            if(prime(i) && !(nDec%i)){
                printf("%d x ",n=i);
                nDec/=i;
                break;
            }
    printf("%d.\n",nDec);
    return 0;
}

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2016-07-06
在isPrime最后一行添加一个return isPrime;就可以了
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;
}
return isPrime;
}本回答被提问者采纳
相似回答