c语言计算素数个数并求和
时间: 2024-05-05 18:22:47 浏览: 222
以下是用C语言计算素数个数并求和的代码:
```c
#include <stdio.h>
int is_prime(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 n, sum = 0, count = 0;
printf("请输入一个正整数n: ");
scanf("%d", &n);
for (int i = 2; i <= n; i++) {
if (is_prime(i)) { // 如果是素数
count++; // 素数个数加1
sum += i; // 素数的和加上i
}
}
printf("1~%d中共有%d个素数,它们的和为%d。\n", n, count, sum);
return 0;
}
```
代码解释:
1. `is_prime` 函数用于判断一个数是否为素数,如果是素数则返回1,否则返回0。
2. 在 `main` 函数中,首先通过 `scanf` 函数获取用户输入的正整数 `n`。
3. 然后用一个循环遍历从2到n的每一个数,如果是素数,则累加素数个数和素数的和。
4. 最后输出统计结果。
注意:此代码中假定用户输入的是正整数。如果需要更严格的输入判断,请自行添加代码。
阅读全文