c语言的欧拉筛法怎么写
时间: 2023-08-31 13:21:38 浏览: 130
### 回答1:
C语言中欧拉筛法的实现方法是:首先初始化长度为 n+1 的 bool 数组 s,其中 s[0] 和 s[1] 均为 false,s[2] 开始全部设为 true;然后从 2 开始遍历到比 n 小的最大素数,如果 s[i] 为 true,则将 s[2*i] 至 s[n] 均设为 false。遍历完成后,s[i] 为 true 的 i 即为素数。
### 回答2:
欧拉筛法是一种用于求解素数的算法,它能够高效地找出一定范围内所有的素数。下面是用C语言实现欧拉筛法的代码:
```c
#include <stdio.h>
#define MAXN 1000000
int isPrime[MAXN+1];
void sieveOfEratosthenes(int n) {
// 将isPrime数组中所有的元素初始化为1
for (int i = 0; i <= n; i++) {
isPrime[i] = 1;
}
isPrime[0] = isPrime[1] = 0; // 0和1不是素数
// 从2开始进行筛选
for (int i = 2; i * i <= n; i++) {
if (isPrime[i] == 1) {
// 将i的倍数标记为非素数
for (int j = i * i; j <= n; j += i) {
isPrime[j] = 0;
}
}
}
}
int main() {
int n;
printf("请输入一个整数n:");
scanf("%d", &n);
sieveOfEratosthenes(n);
printf("小于等于%d的所有素数有:", n);
for (int i = 2; i <= n; i++) {
if (isPrime[i] == 1) {
printf("%d ", i);
}
}
return 0;
}
```
这段代码中,首先定义了一个用于标记素数的数组isPrime,长度为n+1。然后通过sieveOfEratosthenes函数,将所有的元素初始化为1,表示都是素数。接下来,将0和1标记为非素数。然后使用两个嵌套循环,从2开始筛选素数。如果某个数i是素数,则将其所有的倍数标记为非素数。最后,根据isPrime数组中的标记结果,输出小于等于n的所有素数。
### 回答3:
欧拉筛法是一种用来快速找出一定范围内所有素数的算法。以下是一个用C语言实现欧拉筛法的示例代码:
```c
#include <stdio.h>
#include <stdbool.h>
#define MAX_SIZE 1000000
void eulerSieve(int n) {
bool isPrime[MAX_SIZE];
for (int i = 0; i <= n; i++) {
isPrime[i] = true;
}
for (int p = 2; p * p <= n; p++) {
// 如果p是素数
if (isPrime[p] == true) {
// 将p的倍数标记为非素数
for (int i = p * p; i <= n; i += p) {
isPrime[i] = false;
}
}
}
// 输出所有素数
printf("素数:");
for (int p = 2; p <= n; p++) {
if (isPrime[p]) {
printf("%d ", p);
}
}
printf("\n");
}
int main() {
int n;
printf("请输入一个正整数n:");
scanf("%d", &n);
eulerSieve(n);
return 0;
}
```
在这个代码中,我们先定义了一个大小为`MAX_SIZE`的布尔数组`isPrime`,用于记录是否是素数。然后我们将数组中所有元素初始化为`true`,表示都先假设是素数。
接下来,我们从2开始遍历到n,如果当前遍历到的数p是素数,则将其倍数(2p, 3p, 4p...)标记为非素数,即将对应的`isPrime`数组元素改为`false`。
最后,我们遍历`isPrime`数组,找出所有为`true`的索引,即为素数,并输出。
这样,通过欧拉筛法,我们可以快速找出给定范围内的所有素数。
阅读全文