日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

梅森素数 判定总结

發布時間:2024/5/24 综合教程 32 生活家
生活随笔 收集整理的這篇文章主要介紹了 梅森素数 判定总结 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

梅森素數

定義:

if m是一個正整數 and 2^m-1是一個素數 then m是素數
if m是一個正整數 and m是一個素數 then M(m)=2^m-1被稱為第m個梅森數
if p是一個素數 and M(p)是一個素數 then M(p)被稱為梅森素數

Lucas-Lehmer判定法:判定一個梅森數是否是梅森素數

設p是素數,第p個梅森數為M(p)為2^p-1,r1 = 4,對于k >= 2

r(k) = r(k+1)^2-2(modM(p)), 0 <= r(k) <= M(p)

可以得到r(k)序列,則有M(p)是素數,當且僅當r(p-1) = 0(mod M(p))

推論:設p是素數,M(p)為第p個梅森數,則算法復雜度為O(n^3)

梅森素數 - nefu 120

思路:R.1 = 4;R.k = (R.k-1 ^ 2 - 2) % Mp;

如果R.p-1 == 0,則是梅森素數,否則不是。
特殊判斷:p == 2,即Mp = 3是梅森素數。

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>

using namespace std;
typedef long long ll;

ll multi(ll a, ll b, ll m)
{
    ll ret = 0;
    while(b>0)
    {
        if(b&1)
        {
            ret = (ret+a)%m;
        }
        b >>= 1;
        a = (a<<1)%m;
    }
    return ret;
}
int main()
{
    ll sum = 1, data[66], tmp;
    int n, p;
    data[1] = 4;
    cin >> n;
    while(n--)
    {
        sum = 1;
        cin >> p;
        sum <<= p;
        sum -= 1;
        for(int i = 2; i <= p-1; i++)
        {
            tmp = multi(data[i-1],data[i-1],sum);
            data[i] = (tmp-2)%sum;
        }
        if(p == 2)
            cout << "yes" << endl;
        else
        {
            if(data[p-1] == 0)
                cout << "yes" <<endl;
            else
                cout << "no" << endl;
        }
    }
    return 0;
}

模板:

long long multi(long long a, long long b, long long m){//實現a * b % m的操作,用2 * 3 = 6模擬一下就懂了
    long long ans = 0;
    while(b > 0){
        if(b & 1)  ans = (ans+a) % m;
        b >>= 1;
        a = (a<<1) % m;
    }
    return ans;
}
//判斷是否是梅森素數
bool is_msPrime(int p){
    long long r[70];
    long long m = 1;
    m <<= p;  m -=1;//求出Mp;
    r[1] = 4LL;
    if(p == 2)  return true;
    for(int i = 2; i <= p-1; ++i)
        r[i] = (multi(r[i-1],r[i-1],m)-2) % m;
    if(r[p-1] == 0)  return true;
    return false;
}

Miller-rabin 素數測試:直接判斷M(p)是不是素數

理論知識:

費馬小定理: 對于素數p和任意整數a,有ap ≡ a(mod p)(同余)。反過來,滿足ap ≡ a(mod p),p也幾乎一定是素數。

偽素數: 如果n是一個正整數,如果存在和n互素的正整數a滿足 an-1 ≡ 1(mod n),我們說n是基于a的偽素數。如果一個數是偽素數,那么它幾乎肯定是素數。

Miller-Rabin測試: 不斷選取不超過n-1的基b(s次),計算是否每次都有bn-1 ≡ 1(mod n),若每次都成立則n是素數,否則為合數。

還有一個定理,能提高Miller測試的效率:

二次探測定理: 如果p是奇素數,則 x2 ≡ 1(mod p)的解為 x = 1 || x = p - 1(mod p);

兩個高效求解a*b%m a^b%m的方法
// a * b % n
//例如: b = 1011101那么a * b mod n = (a * 1000000 mod n + a * 10000 mod n + a * 1000 mod n + a * 100 mod n + a * 1 mod n) mod n 

ll mod_mul(ll a, ll b, ll n) {
    ll res = 0;
    while(b) {
        if(b&1)    res = (res + a) % n;
        a = (a + a) % n;
        b >>= 1;
    }
    return res;
}
//a^b % n
//同理
ll mod_exp(ll a, ll b, ll n) {
    ll res = 1;
    while(b) {
        if(b&1)    res = mod_mul(res, a, n);
        a = mod_mul(a, a, n);
        b >>= 1;
    }
    return res;
}

代碼如下:

bool miller_rabin(ll n) {
    if(n == 2 || n == 3 || n == 5 || n == 7 || n == 11)    return true;
    if(n == 1 || !(n%2) || !(n%3) || !(n%5) || !(n%7) || !(n%11))    return false;

    ll x, pre, u;
    int i, j, k = 0;
    u = n - 1;    //要求x^u % n

    while(!(u&1)) {    //如果u為偶數則u右移,用k記錄移位數
        k++; u >>= 1;
    }

    srand((ll)time(0));
    for(i = 0; i < S; ++i) {    //進行S次測試
        x = rand()%(n-2) + 2;    //在[2, n)中取隨機數
        if((x%n) == 0)    continue;

        x = mod_exp(x, u, n);    //先計算(x^u) % n,
        pre = x;
        for(j = 0; j < k; ++j) {    //把移位減掉的量補上,并在這地方加上二次探測
            x = mod_mul(x, x, n);
            if(x == 1 && pre != 1 && pre != n-1)    return false;    //二次探測定理,這里如果x = 1則pre 必須等于 1,或則 n-1否則可以判斷不是素數
            pre = x;
        }
        if(x != 1)    return false;    //費馬小定理
    }
    return true;
}

總結

以上是生活随笔為你收集整理的梅森素数 判定总结的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: www国产亚洲精品久久网站 | 欧美精品免费一区二区 | 美腿丝袜av | 国产精品刘玥久久一区 | 91一区二区三区四区 | 在线免费观看欧美大片 | 四虎免费看黄 | 午夜福利理论片在线观看 | 办公室大战高跟丝袜秘书经理ol | 在线观看国产免费视频 | 欧美日韩一区二区三区不卡视频 | 四虎成人在线观看 | 麻豆一区在线 | 亚洲精品www久久久久久广东 | 欧美一级黄色片视频 | 久久免费看少妇 | 天天综合射 | 成人区人妻精品一区二 | 91精品国产91久久久久久久久久久久 | 国产精品久久久久久久久久久久久久久久久 | 成年人福利网站 | 少妇av一区二区 | 国产丰满农村老妇女乱 | av女星全部名单 | 日本少妇xxxx软件 | 成人黄网免费观看视频 | 男女午夜视频 | 久精品国产 | 亚洲成人aaa | 亚洲av永久无码国产精品久久 | 国产一区亚洲二区三区 | 九色91porny | 欧美男女交配 | 波多野结衣影院 | 久久精品国产电影 | 亚洲AV成人无码精品久久盆瓶 | 免费在线观看的黄色网址 | 午夜av一区| 国产精品推荐 | 日韩av综合网| 久久婷婷亚洲 | 欧美三日本三级少妇三级99观看视频 | 欧美一级黑人 | 亚洲AV午夜福利精品一级无码 | 国产精品欧美亚洲 | 成人福利小视频 | 欧美在线视频一区二区 | 日韩欧美中文字幕一区二区三区 | 青青草五月天 | 深夜福利视频在线 | 亚洲成人777 | 韩国美女啪啪 | 亚洲日本影院 | 色综合久久中文字幕无码 | 男人天堂a| 日韩二三区 | 午夜精品美女久久久久av福利 | 少妇一边呻吟一边说使劲视频 | 狠狠操伊人| 日本五十路女优 | 国产精品入口麻豆九色 | 操xxxx| 日本久久久久久 | 欧美精品久久久久a | 亚洲精品国产成人无码 | 欧洲视频在线观看 | 日韩免费在线播放 | 波多野吉衣av无码 | 2022av视频 | 欧美国产乱视频 | 日韩激情免费 | 黄色网址在线免费播放 | 自拍三区 | 国产学生美女无遮拦高潮视频 | 谁有免费的黄色网址 | 午夜免费观看视频 | xxxx.国产 | 成人免费观看视频 | 成人宗合| 欧美一区日韩一区 | 国产亚洲精品久久久久丝瓜 | 91蝌蚪少妇偷拍 | 黄页在线播放 | 亚洲av无码久久精品狠狠爱浪潮 | 色哟哟一区二区三区四区 | 大尺度床戏揉捏胸视频 | 91麻豆精品国产91久久久久久 | 久久99精品国产.久久久久 | 99久久久无码国产精品免费麻豆 | 天天爽影院 | 亚洲理论电影在线观看 | 亚洲视频在线网 | 日本人xxxⅹ18hd19hd | 黄色一级黄色片 | 欧美性视频在线播放 | julia中文字幕在线 | 91欧美一区二区三区 | 亚洲国产情侣 | 97欧美视频 |