C语言编程题——分解质因数。。帮忙改正一下。。
每个非素数(合数)都可以写成几个素数(也可称为质数)相乘的形式,这几个素数就都叫做这个合数的质因数。比如,6可以被分解为2x3,而24可以被分解为2x2x2x3。现在,你...
每个非素数(合数)都可以写成几个素数(也可称为质数)相乘的形式,这几个素数就都叫做这个合数的质因数。比如,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;
}
} 展开
现在,你的程序要读入一个[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;
}
} 展开
2个回答
展开全部
//#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;
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询