判断素数 is_prime()

本文介绍两种不同的素数判断方法,并对比了它们的效率。第一种方法通过遍历所有小于等于根号x的整数来判断;第二种方法则进一步优化,只检查到不大于根号x的整数,减少了不必要的计算,提高了程序运行效率。

1.donnot use this if x is very large or small

int is_prime(int x)

{

int i;

for(i = 2;i * i <= x;i++)

{

if(x%i == 0) return 0;

}

return 1;

}

2.better way

int is_prime(int x)

{

int i,m;

assert(x >= 0);

if(x == 1) return 0;

m = floor(sqrt(x) + 0.5);

for(i = 2;i <= m;i++)

{

if(x%i == 0) return 0;

}

return 1;

}

在C语言中,若要使用`is_prime`函数求指定区间内素数的个数,可先定义一个`is_prime`函数用于判断一个数是否素数,再遍历指定区间内的所有数,调用`is_prime`函数进行判断,若为素数则计数器加1。 以下是示例代码: ```c #include <stdio.h> #include <stdbool.h> #include <math.h> // 判断一个数是否素数 bool is_prime(int num) { if (num <= 1) { return false; } for (int i = 2, n = sqrt(num); i <= n; i++) { if (num % i == 0) { return false; } } return true; } // 计算指定区间内素数的个数 int count_primes(int start, int end) { int count = 0; for (int i = start; i <= end; i++) { if (is_prime(i)) { count++; } } return count; } int main() { int start, end; printf("请输入区间的起始值和结束值(用空格分隔):"); scanf("%d %d", &start, &end); int prime_count = count_primes(start, end); printf("区间 [%d, %d] 内素数的个数为:%d\n", start, end, prime_count); return 0; } ``` ### 代码解释 1. **`is_prime`函数**:用于判断一个数是否素数。若输入的数小于等于1,直接返回`false`;否则,从2开始到该数的平方根进行遍历,若能被整除则返回`false`,否则返回`true`[^4]。 2. **`count_primes`函数**:用于计算指定区间`[start, end]`内素数的个数。遍历该区间内的所有数,调用`is_prime`函数进行判断,若为素数则计数器`count`加1。 3. **`main`函数**:从用户输入获取区间的起始值和结束值,调用`count_primes`函数计算素数的个数,并输出结果。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值