c语言编写函数判断素数

2024-12-29 20:06:04
推荐回答(5个)
回答1:

/判断是不是素数 

#include

int prime(int a);//函数声明

int main()

{

int n,i;

scanf("%d",&n);

if(prime(n)==1) //return返回值1

printf("prime");

else

printf("not prime") ;

}

int prime(int a)

{

int i;

for(i=2;i

if(a%i==0)

return 0;//a%i==0不成立

else 

return 1;//a%i==0成立

}

扩展资料:

素数的算法

1、素数:除了1和本身外无法被其他自然数整除的数,叫做素数,也称质数,如:2,3,5,7一系列。

2、合数:比1大但不是素数的数称为合数,如:8,9,10一系列。

3、特殊的数字:1和0既不是素数也不是合数。

4、算法:  1>确定性算法   2>随机性算法  3>Eratosthenes算法。

回答2:

#include
int isprime(int i); //大小写错误
void main() //省略是默认返回值为int
{
int number ;
printf("Please input a number to test if it is a prime:" );
scanf(" %d",&number);
if (isprime(number)==1) //调用判断素数的函数isPrime,注意括号的位置
printf("Is a prime!\n");
else
printf("Is not a prime!\n");
}// 子函数isPrime的声明和定义如下:
int isprime(int i)
{
int a;
for(a=2;a if(i%a==0)break;
if(a>=i)return 1;
else return 0;
}

回答3:

main()
{
int number ;
printf("Please input a number to test if it is a prime:" );
scanf("%d",&number);
if (isprime(number==1)) ///改成 if (isprime(number)==1)
printf("Is a prime!\n");
else
printf("Is not a prime!\n");
}// 子函数isPrime的声明和定义如下:
int isprime(int i)
{
int a;
for(a=1;a<=i;a++);
if(i%a==0)break; //这里错,当a=1时,就break了
if(a==i)return 1;
else return 0;
}

改成
int isprime(int i)
{
int a;
if(i==1)return 1;//把当1素数
for(a=2;a<=i;a++);
if(i%a==0)break;
if(a==i)return 1;
else return 0;
}
else return 0;
}
试试

回答4:

/********** Begin **********/
#include

int prime(int a);//函数声明
int flag;
int main()

{

int n,i;

scanf("%d",&n);

if(prime(n)==1) //return返回值1

printf("Yes");
else

printf("No") ;
}

int prime(int a)

{

int i;
for(i=2;i{if(a%i==0)

{flag=0;break;}//a%i==0不成立

else

flag=1;//a%i==0成立
}
if(a==i)
flag=1;
return(flag);
}

/********** End **********/

回答5: