亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mrsroot.c

?? 比較新的功能強大的rsa算法源代碼,方便使用.
?? C
字號:
/*
 *   MIRACL method for modular square root
 *   mrsroot.c 
 *
 *   Siguna Mueller's O(lg(p)^3) algorithm, Designs Codes and Cryptography, 2004 
 * 
 *   This is a little slower for p=1 mod 4 primes, but its not time critical, and
 *   more importantly it doesn't pull in the large powmod code into elliptic curve programs
 *   It does require code from mrjack.c and mrlucas.c
 *
 *   If p=3 mod 4, then  sqrt(a)=a^[(p+1)/4] mod p. Note that for many elliptic curves
 *   (p+1)/4 has very low hamming weight.
 *
 *   (was sqrt(a) = V_{(p+1)/4}(a+1/a,1)/(1+1/a))
 *
 *   Mueller's method is also very simple, uses very little memory, and it works just fine for p=1 mod 8 primes
 *   (for example the "annoying" NIST modulus 2^224-2^96+1)
 *   Also doesn't waste time on non-squares, as a jacobi test is done first
 *
 *   If you know that the prime is 3 mod 4, and you know that x is almost certainly a QR
 *   then the jacobi-dependent code can be deleted with some space savings.
 * 
 *   NOTE - IF p IS NOT PRIME, THIS CODE WILL FAIL SILENTLY!
 *
 *   Copyright (c) 2008 Shamus Software Ltd.
 */

#include <stdlib.h>
#include "miracl.h"

BOOL nres_sqroot(_MIPD_ big x,big w)
{ /* w=sqrt(x) mod p. This depends on p being prime! */
    int t,js;
   
#ifdef MR_OS_THREADS
    miracl *mr_mip=get_mip();
#endif
    if (mr_mip->ERNUM) return FALSE;

    copy(x,w);
    if (size(w)==0) return TRUE; 

    MR_IN(100)

    redc(_MIPP_ w,w);   /* get it back into normal form */

    if (size(w)==1) /* square root of 1 is 1 */
    {
        nres(_MIPP_ w,w);
        MR_OUT
        return TRUE;
    }

    if (size(w)==4) /* square root of 4 is 2 */
    {
        convert(_MIPP_ 2,w);
        nres(_MIPP_ w,w);
        MR_OUT
        return TRUE;
    }

    if (jack(_MIPP_ w,mr_mip->modulus)!=1) 
    { /* Jacobi test */ 
        zero(w);
        MR_OUT
        return FALSE;
    }

    js=mr_mip->pmod8%4-2;     /* 1 mod 4 or 3 mod 4 prime? */

    incr(_MIPP_ mr_mip->modulus,js,mr_mip->w10);
    subdiv(_MIPP_ mr_mip->w10,4,mr_mip->w10);    /* (p+/-1)/4 */

    if (js==1)
    { /* 3 mod 4 primes - do a quick and dirty sqrt(x)=x^(p+1)/4 mod p */
        nres(_MIPP_ w,mr_mip->w2);
        copy(mr_mip->one,w);
        forever
        { /* Simple Right-to-Left exponentiation */

            if (mr_mip->user!=NULL) (*mr_mip->user)();
            if (subdiv(_MIPP_ mr_mip->w10,2,mr_mip->w10)!=0)
                nres_modmult(_MIPP_ w,mr_mip->w2,w);
            if (mr_mip->ERNUM || size(mr_mip->w10)==0) break;
            nres_modmult(_MIPP_ mr_mip->w2,mr_mip->w2,mr_mip->w2);
        }
 
 /*     nres_moddiv(_MIPP_ mr_mip->one,w,mr_mip->w11); 
        nres_modadd(_MIPP_ mr_mip->w11,w,mr_mip->w3);  
        nres_lucas(_MIPP_ mr_mip->w3,mr_mip->w10,w,w);
        nres_modadd(_MIPP_ mr_mip->w11,mr_mip->one,mr_mip->w11); 
        nres_moddiv(_MIPP_ w,mr_mip->w11,w); */
    } 
    else
    { /* 1 mod 4 primes */
        for (t=1; ;t++)
        { /* t=1.5 on average */
            if (t==1) copy(w,mr_mip->w4);
            else
            {
                premult(_MIPP_ w,t,mr_mip->w4);
                divide(_MIPP_ mr_mip->w4,mr_mip->modulus,mr_mip->modulus);
                premult(_MIPP_ mr_mip->w4,t,mr_mip->w4);
                divide(_MIPP_ mr_mip->w4,mr_mip->modulus,mr_mip->modulus);
            }

            decr(_MIPP_ mr_mip->w4,4,mr_mip->w1);
            if (jack(_MIPP_ mr_mip->w1,mr_mip->modulus)==js) break;
            if (mr_mip->ERNUM) break;
        }
    
        decr(_MIPP_ mr_mip->w4,2,mr_mip->w3);
        nres(_MIPP_ mr_mip->w3,mr_mip->w3);
        nres_lucas(_MIPP_ mr_mip->w3,mr_mip->w10,w,w); /* heavy lifting done here */
        if (t!=1)
        {
            convert(_MIPP_ t,mr_mip->w11);
            nres(_MIPP_ mr_mip->w11,mr_mip->w11);
            nres_moddiv(_MIPP_ w,mr_mip->w11,w);
        }
    }
    
    MR_OUT
    return TRUE;
}

BOOL sqroot(_MIPD_ big x,big p,big w)
{ /* w = sqrt(x) mod p */
#ifdef MR_OS_THREADS
    miracl *mr_mip=get_mip();
#endif
    if (mr_mip->ERNUM) return FALSE;

    MR_IN(101)

    if (subdivisible(_MIPP_ p,2))
    { /* p must be odd */
        zero(w);
        MR_OUT
        return FALSE;
    }

    prepare_monty(_MIPP_ p);
    nres(_MIPP_ x,w);
    if (nres_sqroot(_MIPP_ w,w))
    {
        redc(_MIPP_ w,w);
        MR_OUT
        return TRUE;
    }

    zero(w);
    MR_OUT
    return FALSE;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品一区二区三区免费| 亚洲欧美日韩国产一区二区三区| 国产精品乱人伦| 91麻豆免费在线观看| 亚洲h精品动漫在线观看| 日韩一区国产二区欧美三区| 国产一区91精品张津瑜| 亚洲欧洲制服丝袜| 中文字幕av一区二区三区| 色先锋aa成人| 国产精品一区二区无线| 亚洲与欧洲av电影| 久久久久97国产精华液好用吗| www.色综合.com| 麻豆国产精品官网| 亚洲精品视频免费看| 精品盗摄一区二区三区| 一本一道综合狠狠老| 色av综合在线| 国产福利一区在线观看| 日韩av不卡在线观看| 中文字幕一区二区三区乱码在线| 日韩午夜激情视频| 久久麻豆一区二区| 国产精品久线在线观看| 久久综合久久综合九色| 91麻豆精品国产91久久久久 | 中文字幕日韩一区| 1024亚洲合集| 日本伊人色综合网| 风间由美一区二区三区在线观看| 免费在线观看日韩欧美| 天使萌一区二区三区免费观看| 亚洲免费电影在线| 免费欧美在线视频| www.日本不卡| 日韩欧美一级二级三级久久久| 欧美性生活久久| 欧美亚洲国产怡红院影院| 欧美一区二区三区色| 91精品国产麻豆国产自产在线| 久久久99精品久久| 国产欧美日本一区视频| 久久精品一级爱片| 亚洲曰韩产成在线| 成人午夜精品在线| 不卡一区中文字幕| 色狠狠av一区二区三区| 精品久久久久久久久久久久包黑料 | 秋霞电影网一区二区| 国产不卡一区视频| 欧美精品视频www在线观看| 欧美日韩一区二区三区免费看| 色婷婷精品久久二区二区蜜臂av | 久久精品亚洲国产奇米99| 亚洲综合色视频| 成人18精品视频| 欧美sm美女调教| 肉色丝袜一区二区| 在线观看亚洲精品| 日韩一区二区三区三四区视频在线观看 | 最新久久zyz资源站| 日本一区二区三区高清不卡| 午夜不卡av免费| 经典三级在线一区| 欧美一级在线视频| 婷婷综合另类小说色区| 欧美伊人久久久久久久久影院| 国产拍欧美日韩视频二区| 韩日欧美一区二区三区| 97精品国产97久久久久久久久久久久| 色综合久久99| 亚洲欧美日韩国产综合| av一区二区三区四区| 国产精品日日摸夜夜摸av| 国内精品第一页| 26uuu亚洲婷婷狠狠天堂| 久久精品国产亚洲5555| 96av麻豆蜜桃一区二区| 国产精品第13页| caoporn国产一区二区| 中文字幕亚洲在| 91麻豆文化传媒在线观看| 亚洲三级视频在线观看| 欧美伊人久久大香线蕉综合69| 一区二区三区中文字幕精品精品| 极品瑜伽女神91| 精品av久久707| 国产激情视频一区二区三区欧美| 国产亚洲欧洲997久久综合| 高清久久久久久| 亚洲欧洲av在线| 欧美色图在线观看| 日本成人在线看| 国产午夜精品久久| 91麻豆国产自产在线观看| 亚洲午夜久久久久久久久电影院| 国产激情视频一区二区三区欧美| 国产午夜亚洲精品羞羞网站| 成人亚洲精品久久久久软件| 亚洲欧美一区二区三区孕妇| 欧美偷拍一区二区| 蜜臀91精品一区二区三区| 国产午夜久久久久| 色久优优欧美色久优优| 日本成人中文字幕在线视频| 亚洲丝袜制服诱惑| 欧美日韩一区久久| 精品一区二区三区在线观看国产 | 成人性视频免费网站| 亚洲一区二区五区| 精品国产亚洲在线| 91麻豆免费看| 国产精品一区免费在线观看| 一区二区三区在线视频观看| 欧美大尺度电影在线| 99久久精品久久久久久清纯| 日韩福利电影在线观看| 亚洲国产成人午夜在线一区| 欧美美女视频在线观看| 成人综合日日夜夜| 美日韩一区二区三区| 亚洲欧美日韩在线不卡| 亚洲精品在线三区| 欧美日免费三级在线| 成人免费看片app下载| 日本不卡视频一二三区| 亚洲视频免费在线观看| 久久视频一区二区| 欧美一区日韩一区| 色综合 综合色| 国产精品亚洲人在线观看| 日韩电影在线看| 亚洲夂夂婷婷色拍ww47| 国产精品萝li| 久久久不卡网国产精品一区| 91精品国产色综合久久不卡电影| 91麻豆精品秘密| www.欧美日韩| 丁香天五香天堂综合| 国产在线观看免费一区| 免费人成黄页网站在线一区二区| 亚洲一级二级三级| 亚洲日本一区二区| 国产精品私人自拍| 日本一区二区动态图| 亚洲精品一区二区三区在线观看| 91精品国产综合久久香蕉麻豆| 91久久精品网| 91国偷自产一区二区开放时间| 91在线小视频| 91丨九色porny丨蝌蚪| av亚洲产国偷v产偷v自拍| 粉嫩绯色av一区二区在线观看| 国产精品自拍网站| 国产河南妇女毛片精品久久久| 久久精品72免费观看| 久久精品国产亚洲高清剧情介绍 | 一区二区免费在线| 一区二区三区不卡视频| 亚洲欧美日韩久久| 一区二区国产盗摄色噜噜| 亚洲精品国产一区二区精华液| 成人免费小视频| 一区二区高清视频在线观看| 亚洲综合成人网| 午夜精品aaa| 精品一二三四在线| 成人免费看片app下载| 色综合久久中文字幕综合网| 色婷婷亚洲综合| 欧美日本一区二区三区四区| 懂色一区二区三区免费观看| 国产不卡免费视频| eeuss影院一区二区三区| 日本韩国精品在线| 欧美丰满一区二区免费视频| 欧美xxxxx牲另类人与| 国产日韩影视精品| 亚洲另类在线一区| 亚洲电影你懂得| 韩国精品一区二区| 99精品在线观看视频| 欧美日韩国产精选| 精品动漫一区二区三区在线观看| 中文一区二区在线观看| 亚洲三级小视频| 麻豆久久久久久| 成人av网站大全| 欧美一级片免费看| 日本一区二区三区四区| 亚洲成av人片在www色猫咪| 韩国精品免费视频| 在线视频综合导航| 国产亚洲欧美日韩俺去了| 国产精品国产馆在线真实露脸| 五月天久久比比资源色| 懂色av一区二区在线播放| 欧美日韩成人综合在线一区二区| 久久亚洲综合av|