求5000以内素数,每一行显示十个素数,统计所有素数之和用c语言写个程序
时间: 2024-05-12 14:18:22 浏览: 81
好的,这是一个求解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。
相关问题
求5000以内的素数,每行显示十个素数,统计所有素数之和c语言
好的,我知道了。以下是代码:
```
#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;
}
```
希望能够帮到你。
用c语言写一个求999以内的素数的程序
#include <stdio.h>
int main() {
int i, j, is_prime;
// 从2开始遍历到999
for (i = 2; i <= 999; i++) {
is_prime = 1; // 假设i是素数
// 判断i是否为素数
for (j = 2; j < i; j++) {
if (i % j == 0) {
is_prime = 0; // i不是素数
break;
}
}
// 如果i是素数,打印出来
if (is_prime) {
printf("%d ", i);
}
}
return 0;
}
阅读全文