C语言编写一个判断素数的函数,函数原型为int isprime(int n);若n为素数,函数返回值为1,否则返回值为0;主函数中调用该函数,输出100到200之间所有的素数,并计算所有素数的和
时间: 2024-03-27 19:36:16 浏览: 25
好的,下面是 C 语言的实现代码:
```c
#include <stdio.h>
int isprime(int n)
{
if (n <= 1) {
return 0;
}
for (int i = 2; i * i <= n; i++) {
if (n % i == 0) {
return 0;
}
}
return 1;
}
int main()
{
int sum = 0;
printf("100到200之间的素数有:\n");
for (int i = 100; i <= 200; i++) {
if (isprime(i)) {
printf("%d ", i);
sum += i;
}
}
printf("\n它们的和为:%d\n", sum);
return 0;
}
```
首先定义了一个 `isprime` 函数,用于判断一个数是否为素数,通过遍历从 2 到 $\sqrt{n}$ 的所有数,如果存在某个数可以整除 n,那么 n 不是素数,返回 0;否则 n 是素数,返回 1。
在主函数中,使用 for 循环遍历 100 到 200 之间的所有数,对每个数调用 isprime 函数判断是否为素数,如果是素数,则输出该数,累加到 sum 变量中。最后输出所有素数的和。
相关问题
用C语言编写一个函数isprime,判断整数N是否为素数
以下是用C语言编写的判断整数N是否为素数的函数isprime:
```c
#include <stdio.h>
#include <math.h>
int isprime(int N){
int i;
if(N < 2) return 0; //小于2的数不是素数
for(i = 2; i <= sqrt(N); i++){ //从2到sqrt(N)枚举
if(N % i == 0) return 0; //如果能整除,不是素数
}
return 1; //否则是素数
}
int main(){
int n;
printf("请输入一个整数n:");
scanf("%d", &n);
if(isprime(n)) printf("%d是素数\n", n);
else printf("%d不是素数\n", n);
return 0;
}
```
函数isprime的思路是从2到sqrt(N)枚举每个可能的因子i,如果N能被i整除,则N不是素数;否则N是素数。如果N小于2,则不是素数。函数返回1表示N是素数,返回0表示N不是素数。
在主函数中,先输入一个整数n,然后调用isprime函数判断n是否为素数,最后输出结果。
用c语言编写函数isprime(int n)判断n是否为素数,如果是,则返回1,否则返回0
以下是用C语言编写的判断素数的代码:
```c
#include <stdio.h>
int isprime(int n) {
int i;
if (n < 2) { // 1不是素数
return 0;
}
for (i = 2; i * i <= n; i++) { // 判断n是否能被2~sqrt(n)之间的数整除
if (n % i == 0) {
return 0;
}
}
return 1;
}
int main() {
int n;
printf("请输入一个整数:\n");
scanf("%d", &n);
if (isprime(n)) {
printf("%d是素数\n", n);
} else {
printf("%d不是素数\n", n);
}
return 0;
}
```
这个函数使用了一个for循环,从2开始到sqrt(n)结束,判断n是否能被这些数整除。如果n能被其中任意一个数整除,那么它就不是素数,函数返回0;否则,它是素数,函数返回1。注意,在函数中,1不是素数,因此当n小于2时,函数返回0。