十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
#include stdio.h
成都创新互联从2013年开始,先为芗城等服务建站,芗城等地企业,进行企业商务咨询服务。为芗城企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。
#include math.h
//判断整数是否为素数
int isPrime(int n)
{
int i;
for(i=2;i=(int)sqrt(n);i++) //遍历从2~n的平方根向下取整
if(n%i == 0) //如果有i能被n整除,则n不是素数,返回0,否则返回1
return 0;
return 1;
}
//编写测试主函数
int main()
{
int n;
scanf("%d",n);
if(n2)
{
printf("输入错误!\n");
return -1;
}
if(isPrime(n)) //调用素数判断函数
printf("%d is a prime number\n",n);
else
printf("%d is not a prime number\n",n);
return 0;
}
看代码:
#include stdio.h
#include math.h
// 判断是否是素数,是的话返回 1,不是返回 0
int is_prime(int num)
{
if (num 2)
{
return 0;
}
int i, tmp = (int)sqrt(num);
for (i = 2; i = tmp; ++i)
{
if (num % i == 0)
{
return 0;
}
}
return 1;
}
int main(int argc, char** argv)
{
int i;
printf ("1 ~ 100 的素数:\n");
for (i = 1; i = 100; ++i)
{
if (is_prime(i))
{
printf ("%d\n", i);
}
}
return 0;
}
运行:
#include stdio.h
int fun(int x)//
{
if(x2)
return 0;//返回0,非素数
for(int i=2;i*i=x;i++)
if(x%i==0)
return 0;
return 1;//返回1,素数
}
int main()
{
int n;
scanf("%d",n);
if(fun(n)==1)
printf("%d是素数\n",n);
else
printf("%d不是素数\n",n);
return 0;
}
#include
"stdio.h"
#include
"math.h"//判断一个整数是否为素数
bool
prime(int
x)
{
int
i;
for(i=2;i=
sqrt(x);i++)
{
if(x%i==0)
return
false;
}
return
true;
} //判断一个整数(1位或多位)是否每一位都是素数
bool
allPrime(int
a)
{
if(prime(a%10))
//如果个位是素数
{
a=a/10;
return
allPrime(a);
}
else
return
false;
}//
打印出1-5000内满足题意的素数
void
printPrime()
{
int
i;
int
a=0;
for(
i=11;i5000;)
//
1-9
不用再判断了,只有一位。10和5000很明显也不用去判断了,不是素数
{
if(prime(i))
//
如果i是素数,判断个位是不是素数,如果个位不是,不满足第二个条件
{
if(prime(i%10))
//判断个位
{
a=i/10
;
//a就是去掉个位后的数
if(prime(a))
//判断a
是否是素数,如果是,再判断a每一位是否是素数
{
if(allPrime(a))
printf("%d\n",i);
} }
}
i+=2;
}
}int
main()
{
printPrime();
}