写一个c语言的欧拉筛法的函数
时间: 2023-03-13 14:05:40 浏览: 131
我可以为你提供一个简单的C语言欧拉筛法函数:int sieveOfEratosthenes(int n)
{
// 建立一个布尔数组,用于记录素数
bool prime[n+1];
memset(prime, true, sizeof(prime));
for (int p=2; p*p<=n; p++)
{
// 如果p是素数,则将它的倍数标记为非素数
if (prime[p] == true)
{
// 从p*2开始,将2*p、3*p、4*p等标记为非素数
for (int i=p*2; i<=n; i += p)
prime[i] = false;
}
}
// 打印所有素数
for (int p=2; p<=n; p++)
if (prime[p])
cout << p << " ";
}
相关问题
c语言的欧拉筛法怎么写
### 回答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`的索引,即为素数,并输出。
这样,通过欧拉筛法,我们可以快速找出给定范围内的所有素数。
欧拉筛法的C语言代码
下面是一个简单的C语言代码示例,展示了如何使用欧拉筛法找出某个范围内所有的素数:
```c
#include <stdio.h>
#include <stdbool.h>
#define MAX_RANGE 1000000
// 初始化素数数组,并设置为真
bool is_prime[MAX_RANGE+1] = {true};
void sieve_of_eratosthenes(int n) {
int i, j;
for (i = 2; i * i <= n; i++) {
// 如果is_prime[i]仍然为真,则i是素数
if (is_prime[i]) {
// 更新i的倍数,将它们标记为合数
for (j = i * i; j <= n; j += i) {
is_prime[j] = false;
}
}
}
}
// 输出指定范围内的素数
void print_primes(int start, int end) {
printf("素数在 %d 到 %d 范围内:\n", start, end);
for (int i = start; i <= end; i++) {
if (is_prime[i])
printf("%d ", i);
}
printf("\n");
}
int main() {
sieve_of_eratosthenes(MAX_RANGE); // 计算所有小于MAX_RANGE的素数
print_primes(1, MAX_RANGE); // 输出1到MAX_RANGE之间的素数
return 0;
}
```
在这个代码中,我们首先创建了一个布尔数组`is_prime[]`,然后通过循环逐步筛选出素数。`sieve_of_eratosthenes`函数负责筛选,而`print_primes`函数则打印出特定范围内的素数。
阅读全文