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

2024-11-21 20:50:49
推荐回答(2个)
回答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        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;
}

回答2:

在isPrime最后一行添加一个return isPrime;就可以了
int isPrime(int a)
{
int isPrime;
int i;
for(i=2;i if(a%i==0){
isPrime=0;
break;
}
}
if(i>=a){
isPrime=1;
}
return isPrime;
}