求5000以内的素数,每行显示十个素数,统计所有素数之和c语言
时间: 2024-05-03 11:20:29 浏览: 82
好的,我知道了。以下是代码:
```
#include <stdio.h>
int main() {
int count = 0;
long sum = 0;
for (int num = 2; num <= 5000; num++) {
int isPrime = 1;
for (int i = 2; i < num; i++) {
if (num % i == 0) {
isPrime = 0;
break;
}
}
if (isPrime == 1) {
printf("%d ", num);
count++;
sum += num;
if (count == 10) {
printf("\n");
count = 0;
}
}
}
printf("\nSum of all prime numbers: %ld", sum);
return 0;
}
```
希望能够帮到你。
相关问题
求5000以内素数,每一行显示十个素数,统计所有素数之和用c语言写个程序
好的,这是一个求解5000以内素数,并且统计所有素数之和的程序:
```c
#include <stdio.h>
int main() {
int sum = 0, cnt = 0, i, j, is_prime;
for (i = 2; i <= 5000; i++) {
is_prime = 1;
for (j = 2; j < i; j++) {
if (i % j == 0) {
is_prime = 0;
break;
}
}
if (is_prime) {
sum += i;
cnt++;
printf("%d ", i);
if (cnt % 10 == 0) {
printf("\n");
}
}
}
printf("\nsum = %d\n", sum);
return 0;
}
```
该程序使用两层循环,第一层循环枚举2到5000之间的所有数,第二层循环判断当前数是否为素数。如果当前数是素数,则将其加到sum变量中,并且用cnt计数,每输出十个素数就换行。最后输出所有素数的和sum。
c语言求51以内所有素数之和
以下是C语言求51以内所有素数之和的代码:
```c
#include <stdio.h>
int main()
{
int i, j, sum = 0;
for (i = 2; i <= 51; i++) {
for (j = 2; j <= i; j++) {
if (i % j == 0 && i != j) {
break;
}
}
if (i == j) {
sum += i;
}
}
printf("51以内所有素数之和为:%d\n", sum);
return 0;
}
```
代码解释:
首先定义了三个变量i、j和sum,其中i用于循环判断每个数是否为素数,j用于循环判断i是否为素数,sum用于累加素数的和。
然后使用两个for循环,外层循环从2开始到51,内层循环从2开始到i,判断i是否能被j整除且i不等于j,如果满足条件则跳出内层循环,否则继续循环。如果i等于j,则说明i是素数,将其加入sum中。
最后输出51以内所有素数之和。
阅读全文