前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >数学--数论--素数

数学--数论--素数

作者头像
风骨散人Chiam
发布于 2020-11-05 14:57:50
发布于 2020-11-05 14:57:50
43700
代码可运行
举报
文章被收录于专栏:CSDN旧文CSDN旧文
运行总次数:0
代码可运行
定义判断:
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
bool isPrime (int n)
{
	for(int i=2;i*i<=n;i++)
	{
		if(n%i==0) return false;
	}
	else return false;
}

埃氏筛法

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
int primes[N],cnt;
bool bprime[N];
void getPrime(int n){
    memset(bprime,false,sizeof(bprime));
    bprime[0]=true;
    bprime[1]=true;   
 
    for(int i=2;i<=n;i++){
        if(!bprime[i]){
            prime[cnt++]=i;
            for(LL j=i*2;j<=n;j+=i)
                bprime[j]=true;
        }
    }
}
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
int primes[N],cnt;
bool bPrime[N];
void getPrimes(int n){
    memset(bPrime,false,sizeof(bPrime));
 
    for(int i=2;i<=n;i++){
        if(!bPrime[i])
            primes[cnt++]=i;
 
        for(int j=0;j<cnt&&i*primes[j]<n;j++){
            bPrime[i*primes[j]]=true;
            if(i%primes[j]==0)
                break;
        }
    }
}

线筛(欧式筛)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#include<iostream>
#include<bitset>
using namespace std;
bitset<100000010>v;
int prime[6000001];
int m=0;
void primes(int n)
{
    for(int i=2; i*i<=n; i++)
    {
        if(!v[i])
        {
            for(int j=i*i; j<=n; j+=i)
                v[j]=1;
        }
    }
    for(int i=2; i<=n; i++)
        if(!v[i])
            prime[m++]=i;
    for(int i=0; i<m; i++)
        cout<<prime[i]<<endl;
}
int main()
{
    primes(1e3+20);
    return 0;
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019/12/17 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验