c语言求素数100到200的素数
时间: 2023-12-04 07:39:18 浏览: 41
以下是求解100到200的素数的C语言代码示例:
```c
#include <stdio.h>
#define N 200
int main() {
// 标记数组,prime[i]为true表示i是素数,否则为合数
bool prime[N + 1];
for (int i = 2; i <= N; i++) {
prime[i] = true;
}
// 埃氏筛
for (int i = 2; i * i <= N; i++) {
if (prime[i]) {
for (int j = i * i; j <= N; j += i) {
prime[j] = false;
}
}
}
// 输出100到200之间的素数
for (int i = 100; i <= N; i++) {
if (prime[i]) {
printf("%d ", i);
}
}
return 0;
}
```
相关问题
c语言求100到200的素数
以下是三种C语言求100到200的素数的方法:
1. 第一种方法:
```c
#include <stdio.h>
void main() {
int n;
for (int i = 100; i <= 200; i++) {
for (n = 2; n <= i; n++) {
if (i % n == 0) break;
}
if (i == n) {
printf("素数:%d\n", i);
}
}
}
```
2. 第二种方法:
```c
#include <stdio.h>
void main() {
int n;
for (int i = 101; i <= 200; i += 2) {
for (n = 2; n <= i; n++) {
if (i % n == 0) break;
}
if (i == n) {
printf("素数:%d\n", i);
}
}
}
```
3. 第三种方法:
```c
#include <stdio.h>
#include <math.h>
void main() {
int n;
for (int i = 101; i <= 200; i += 2) {
int limit = sqrt(i) + 1;
for (n = 2; n <= limit; n++) {
if (i % n == 0) break;
}
if (n > limit) {
printf("素数:%d\n", i);
}
}
}
```
用C语言求100到200之间的素数
以下是两种C语言求100到200之间的素数的例子:
1. 引用中的代码,输出100到200之间的所有素数并计数:
```c
#include<stdio.h>
#include<math.h>
int main() {
int i, num;
int count = 0;
for (num = 100; num <= 200; num++) {
for (i = 2; i <= sqrt(num); i++) {
if (num % i == 0) break;
}
if (num % i != 0) {
printf("%d\n", num);
count++;
}
}
printf("the sum of prime is %d", count);
return 0;
}
```
2. 引用中的代码,输出100到200之间的所有素数并计数:
```c
#include<stdio.h>
#include<math.h>
int main() {
int i, num;
int count = 0;
for (num = 100; num < 200; num++) {
for (i = 2; i < num; i++) {
if (num % i == 0) break;
}
if (num == i) {
printf("%d\n", num);
count++;
}
}
printf("all is %d\n", count);
return 0;
}
```