c – 素数算法

谁能告诉我如何在C中实现 Sieve of Eratosthenes算法?我需要生成素数但我的算法很慢.

我的代码

#include <stdio.h>

int prime(long int i)
{
    long int j;
    int state = 1;
    for(j=2;j<i;j++)
    {
        if((i%j)==0){state=0;break;}
    }
    return state;
}

int main()
{
    int t;
    long int m,n,i;
    scanf("%d",&t);
    while(t--) {
        scanf("%d %d",&m,&n);
        for(i=m;i<=n;i++)
        {
            if(i==1){
                //do nothing for 1
            } else{
                if(prime(i))printf("%d\n",i);
            }
        }
    }
    return 0;
}

t是测试用例的数量m,n是要打印质数的范围.

解决方法

您需要创建一个与您要查找的最大素数一样大的布尔数组.在开始时它完全初始化为true.

如果i是素数,则此类数组的第i个单元格将为true,否则为false.

从i = 2开始迭代:它是素数,然后将索引倍数为2的任何单元格设置为false.转到下一个素数(i = 3)并执行相同操作.转到下一个素数(它是i = 5:i = 4不是素数:当处理i = 2时,数组[4]被设置为假)并且一次又一次地执行相同操作.

相关文章

/** C+⬑ * 默认成员函数 原来C++类中,有6个默认成员函数: 构造函数 析构函数 拷贝...
#pragma once // 1. 设计一个不能被拷贝的类/* 解析:拷贝只会放生在两个场景中:拷贝构造函数以及赋值运...
C类型转换 C语言:显式和隐式类型转换 隐式类型转化:编译器在编译阶段自动进行,能转就转,不能转就编译...
//异常的概念/*抛出异常后必须要捕获,否则终止程序(到最外层后会交给main管理,main的行为就是终止) try...
#pragma once /*Smart pointer 智能指针;灵巧指针 智能指针三大件//1.RAII//2.像指针一样使用//3.拷贝问...
目录&lt;future&gt;future模板类成员函数:promise类promise的使用例程:packaged_task模板类例程...