用c语言写一个输入n,可以求[2-n]之间所有素数的和的代码
时间: 2023-05-24 07:07:02 浏览: 70
```
#include<stdio.h>
#include<math.h>
int isPrime(int n){ //判断是否为素数的函数
int i;
for(i=2;i<=sqrt(n);i++){
if(n%i==0){
return 0;
}
}
return 1;
}
int main(){
int n,sum=0,i;
printf("请输入n:");
scanf("%d",&n);
for(i=2;i<=n;i++){
if(isPrime(i)){
sum+=i;
}
}
printf("%d到%d之间所有素数的和为:%d\n",2,n,sum);
return 0;
}
```
相关问题
用C语言输入n,求[2-n]之间所有素数的和。
```c
#include <stdio.h>
#include <stdbool.h> // 引入 bool 类型头文件
int main()
{
int n;
scanf("%d", &n);
int sum = 0;
for (int i = 2; i <= n; i++)
{
bool is_prime = true; // 标记是否为素数
for (int j = 2; j < i; j++)
{
if (i % j == 0) // 不是素数
{
is_prime = false;
break;
}
}
if (is_prime) // 是素数
{
sum += i; // 累加和
}
}
printf("%d\n", sum); // 输出和
return 0;
}
```
代码思路:
1. 输入正整数 n;
2. 用变量 sum 记录 2~n 之间所有素数的和,初始为 0;
3. 从 2 开始循环到 n,每个数都判断它是否为素数:
1. 用一个 bool 类型变量 is_prime 标记当前数是否为素数,初始为 true;
2. 对于当前数 i,从 2 开始循环到 i-1,每次判断 i 是否能被 j 整除,如果是,就说明 i 不是素数,将 is_prime 设为 false,退出循环;
3. 如果循环结束后 is_prime 仍为 true,说明 i 是素数,将 sum 加上 i。
4. 循环结束后,输出 sum。
注意事项:
1. 需要引入 bool 类型头文件;
2. 需要将变量 is_prime 的初始值设为 true;
3. 内层循环的终止条件应该是 j < i,而不是 j <= i;
4. 如果某个数不是素数,应该及时退出内层循环,因为后面就不用再判断了。
用C语言写出输入n,输出1-n的素数的代码
```
#include <stdio.h>
int is_prime(int num) {
if (num < 2) {
return 0;
}
for (int i = 2; i * i <= num; i++) {
if (num % i == 0) {
return 0;
}
}
return 1;
}
int main() {
int n;
printf("请输入一个正整数n:");
scanf("%d", &n);
printf("1-%d之间的素数有:\n", n);
for (int i = 2; i <= n; i++) {
if (is_prime(i)) {
printf("%d ", i);
}
}
printf("\n");
return 0;
}
```
阅读全文