几种求素数与验证素数的方法

博主刚写了一篇Luogu T1125的解题报告,里面涉及到欧拉筛法。本篇博文会介绍一些素数筛法和素数验证法。

博主的数论并不是特别好,各路大神轻点喷

素数筛法

1. Eratosthenes筛法

又名:埃拉托斯特尼筛法
时间复杂度:$O(nlog_{2}{log_{2}n})$
难度:☆

具体代码:

memset(check,false,sizeof(check));
int tot=0;
for(int i=2;i<=n;i++)
    if(!check[i])
    {
        prime[++tot]=i;
        for(int j=i*2;j<=n;j+=i)//i的倍数都不是素数
            check[j]=true;
    };

2. Euler筛法

又名:欧拉筛法、线性筛法
时间复杂度:$O(n)$
难度:★

具体代码:

for(int i=2;i<=m;i++)
{
    if(!check[i])prime[++tot]=i;
    for(int j=1;j<=tot;j++)
    {
        if(i*prime[j]>m)break;//超了范围就不做了,减少运行时间
        check[i*prime[j]]=true;//一个数乘另一个数所得到的数一定不是素数
        if(i%prime[j]==0)break;//此时i是一个合数,退出
    };
};

验证素数

普通验证素数法

时间复杂度:$O(\sqrt n)$
难度:☆

bool flag=true;
for(int i=1;i<=trunc(sqrt(prime));i++)
    if(prime%i==0)flag=false;//置不是素数标志

Miller-Rabin

时间复杂度:$O(k*log_{2}n)$ k是次数(见下文)
难度:★★★

这里只说明一下原理,关于代码,自行百度吧。

  • 根据费马小定理,随机选一个数$a\in(1,p)$,若$a^{p-1}\equiv1$(mod p)则很有可能是素数。多次尝试(尝试k次)若都成立若都成立则判定为素数。
  • 但是合数也有可能能通过这一测试:Carmichael数
  • Carmichael概念:
      卡迈克尔数是一种合数,使得对于所有跟n互质的整数a:$a^{n-1}\equiv1$(mod n)
  • 这种数用此方法测试时,除非random出其因子,不然都无法判断为合数。例如:6。
  • 二次探测定理:若n为素数,方程$x^2\equiv1$(mod n)小于n的正整数解只有$x=1$和$x=n-1$。
  • 先计算出m、j,使得$n-1=m*2^j$且j尽可能大。
  • 随机选一个数$a\in(1,n)$
  • 计算x=$a^m$mod n
  • 然后将x不断平方j次,重复如下步骤:
      1. 计算y=$x^2$mod n
      2. 如果y=1并且$x\neq1,n-1$,此时一定不是素数,退出测试
      3. x=y;
      4. 如果y=1,暂时认为是素数,回到2.继续下一轮
    若上述计算中没有满足2.和4.而正常退出,即不满足$a^{n-1}\equiv1$(mod n),一定不是质数

Ps.此方法参考了陈淙靓在清北学堂的课件

原文请查看我的博文
此博文到此结束,感谢惠读

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,761评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,953评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,998评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,248评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,130评论 4 356
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,145评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,550评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,236评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,510评论 1 291
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,601评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,376评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,247评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,613评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,911评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,191评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,532评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,739评论 2 335

推荐阅读更多精彩内容

  • 一、实验目的 学习使用 weka 中的常用分类器,完成数据分类任务。 二、实验内容 了解 weka 中 explo...
    yigoh阅读 8,346评论 5 4
  • thiele插值算法 1点插值算法 function [C,c]=thiele(X,Y,Z)%X为插值点横坐标,Y...
    00crazy00阅读 1,946评论 0 4
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,712评论 0 33
  • 归去来兮。 1.1 说明 本篇为《挑战程序设计竞赛(第2版)》[http://www.ituring.com.cn...
    尤汐Yogy阅读 14,241评论 0 160
  • 工作许多年,期间听闻大事小事倒也颇多,让人受益匪浅,心肠变得冷硬,唯有那么一件小事叫人感动。几年前一个冬天的早...
    混思乱写hs阅读 260评论 0 0