之和质数c语言题判断,C语言经典例题100例——C语言练习实例33解答(质数判断)...
題目:判斷一個數字是否為質數。
程序分析:質數(prime number)又稱素數,有無限個。一個大于1的自然數,除了1和它本身外,不能被其他自然數整除。
程序源代碼:
// 百寶箱工作室 官方網址 http://www.baibaox.com
// 百寶箱工作室業務介紹 http://www.baibaox.com/BusinessIntroduction.html
#include
#include
#define MAX 1000
int prime[MAX];
int isPrimeNaive(int n)
{
int i;
if(n <= 1)
return 0;
for(i = 2; i < n; i++)
if(n % i == 0)
return 0;
return 1;
}
int isPrime(int n)
{
int i;
int limit;
if(n<= 1)
return 0;
if(n == 2)
return 1;
if(n%2 == 0)
return 0;
limit = (int)sqrt((double)n);
for(i = 3; i <= limit; i=i+2)
{
if(n % i == 0)
return 0;
}
return 1;
}
void sieve()
{
int i;
int j;
int limit;
prime[0] = 0;
prime[1] = 0;
for(i = 2; i < MAX; i++)
prime[i] = 1;
limit = (int)sqrt((double)MAX);
for(i = 2; i <= limit; i++)
{
if(prime[i])
for(j = i*i; j <= MAX; j+=i)
prime[j] = 0;
}
}
int isPrimeSieve(int n)
{
if(prime[n])
return 1;
else
return 0;
}
int main()
{
sieve();
printf("N=%d %d\n", 1, isPrime(1));
printf("N=%d %d\n", 2, isPrime(2));
printf("N=%d %d\n", 3, isPrime(3));
printf("N=%d %d\n", 4, isPrime(4));
printf("N=%d %d\n", 7, isPrime(7));
printf("N=%d %d\n", 9, isPrime(9));
printf("N=%d %d\n", 13, isPrime(13));
printf("N=%d %d\n", 17, isPrime(17));
printf("N=%d %d\n", 100, isPrime(100));
printf("N=%d %d\n", 23, isPrime(23));
printf("N=%d %d\n", 1, isPrime(1));
return 0;
}
以上實例運行結果如下:
N=1 0
N=2 1
N=3 1
N=4 0
N=7 1
N=9 0
N=13 1
N=17 1
N=100 0
N=23 1
N=1 0
總結
以上是生活随笔為你收集整理的之和质数c语言题判断,C语言经典例题100例——C语言练习实例33解答(质数判断)...的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【渝粤教育】国家开放大学2018年春季
- 下一篇: 万彩办公大师多页PDF文档去掉空白部分合