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

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

?? helpdlg.cpp

?? RSA算法,大素數生成,加密解密
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
		m_Text+="  C[i]=Sum[j=0 to q](A[i-j]*B[j])+carry[i-1]-carry[i]*0x100000000";
		m_Text+="\r\n";
		m_Text+="  其中carry[-1]=0";
		m_Text+="\r\n";
		m_Text+="  carry[i]=(Sum[j=0 to q](A[i-j]*B[j])+carry[i-1])/0x100000000";
		m_Text+="\r\n";
		m_Text+="  n=p+q-1,若carry[n]>0,則n=n+1,C[n]=carry";
		m_Text+="\r\n";
		m_Text+="\r\n";
        m_Edit.SetWindowText(m_Text);
		break;
	case 6:
        m_Text="";
		m_Text+="\r\n";
		m_Text+="設:";
		m_Text+="\r\n";
		m_Text+="  A=Sum[i=0 to p](A[i]*0x100000000**i)";
		m_Text+="\r\n";
		m_Text+="  B=Sum[i=0 to q](B[i]*0x100000000**i),p>=q";
		m_Text+="\r\n";
		m_Text+="  C=Sum[i=0 to n](C[i]*0x100000000**i)=A/B";
		m_Text+="\r\n";
		m_Text+="";
		m_Text+="\r\n";
		m_Text+="由于無法將B 對A “試商”,我們只能轉換成B[q]對A[p]的試商來得到一個近似值,";
		m_Text+="\r\n";
		m_Text+="所以我們不能夠直接計算C。但是,我們可以一步一步地逼近C";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="顯然:";
		m_Text+="\r\n";
		m_Text+="  (A[p]/B[q]-1)*0x100000000**(p-q)<C";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="令:";
		m_Text+="\r\n";
		m_Text+="  X=0";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="重復:";
		m_Text+="\r\n";
		m_Text+="  A=A-X*B,X=X+(A[p]/B[q]-1)*0x100000000**(p-q),直到A<B";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="則有:";
		m_Text+="\r\n";
		m_Text+="  X=C";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="注意:";
		m_Text+="\r\n";
		m_Text+="  由于大數可理解為0x100000000進制,所以對于任意大數A*0x100000000**k";
		m_Text+="\r\n";
		m_Text+="  都等價于將A 的數組中的各元素左移k 位,不必計算;同樣,除法則等價于右移";
		m_Text+="\r\n";
		m_Text+="\r\n";
        m_Edit.SetWindowText(m_Text);
		break;
	case 7:
        m_Text="";
		m_Text+="\r\n";
		m_Text+="設:";
		m_Text+="\r\n";
		m_Text+="  A=Sum[i=0 to p](A[i]*0x100000000**i)";
		m_Text+="\r\n";
		m_Text+="  B=Sum[i=0 to q](B[i]*0x100000000**i),p>=q";
		m_Text+="\r\n";
		m_Text+="  C=Sum[i=0 to n](C[i]*0x100000000**i)=A%B";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="求模與求商的過程一致,只是由于不需要記錄商而更加簡單:";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="重復:";
		m_Text+="\r\n";
		m_Text+="  A=A-(A[p]/B[q]-1)*0x100000000**(p-q)*B,直到A<B";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="則有:";
		m_Text+="\r\n";
		m_Text+="  A=C";
		m_Text+="\r\n";
		m_Text+="\r\n";
        m_Edit.SetWindowText(m_Text);
		break;
	case 8:
        m_Text="";
		m_Text+="\r\n";
		m_Text+="    在RSA 算法中,往往要在已知A、M的情況下,求 B,使得 (A*B)%M=1。即相當于";
		m_Text+="\r\n";
		m_Text+="求解B、N都是未知數的二元一次不定方程 A*B-M*N=1,的最小整數解。";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    而針對不定方程ax-by=1 的最小整數解,古今中外都進行過詳盡的研究,西方有";
		m_Text+="\r\n";
		m_Text+="著名的歐幾里德算法,即輾轉相除法,中國有秦九韶的“大衍求一術”。歐幾里德算";
		m_Text+="\r\n";
		m_Text+="法是一種遞歸算法,比較容易理解:";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    例如:11x-49y=1,求x";
		m_Text+="\r\n";
		m_Text+="    (a) 11 x - 49 y = 1    49%11=5 ->";
		m_Text+="\r\n";
		m_Text+="    (b) 11 x -  5 y = 1    11%5 =1 ->";
		m_Text+="\r\n";
		m_Text+="    (c)    x -  5 y = 1";
		m_Text+="\r\n";
		m_Text+="    令y=0 代入(c)得x=1";
		m_Text+="\r\n";
		m_Text+="    令x=1 代入(b)得y=2";
		m_Text+="\r\n";
		m_Text+="    令y=2 代入(a)得x=9";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    同理可使用遞歸算法求得任意 ax-by=1(a、b互質)的解,實際上通過分析歸納";
		m_Text+="\r\n";
		m_Text+="將遞歸算法轉換成非遞歸算法就變成了大衍求一術。";
		m_Text+="\r\n";
		m_Text+="\r\n";
        m_Edit.SetWindowText(m_Text);
		break;
	case 9:
        m_Text="";
		m_Text+="\r\n";
		m_Text+="    冪模運算是RSA 核心算法,最直接地決定了RSA 算法的性能,針對快速冪模運算";
		m_Text+="\r\n";
		m_Text+="這一課題,許多西方現代數學家提出了大量的解決方案。通常都是先將冪模運算化簡";
		m_Text+="\r\n";
		m_Text+="為乘模運算。";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    例如求D=C**15 % N,由于:";
		m_Text+="\r\n";
		m_Text+="        a*b % n = (a % n)*(b % n) % n";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    所以:";
		m_Text+="\r\n";
		m_Text+="        C1=C*C % N       =C**2 % N";
		m_Text+="\r\n";
		m_Text+="        C2=C1*C % N      =C**3 % N";
		m_Text+="\r\n";
		m_Text+="        C3=C2*C2 % N     =C**6 % N";
		m_Text+="\r\n";
		m_Text+="        C4=C3*C % N      =C**7 % N";
		m_Text+="\r\n";
		m_Text+="        C5=C4*C4 % N     =C**14 % N";
		m_Text+="\r\n";
		m_Text+="        C6=C5*C % N      =C**15 % N ";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    即:";
		m_Text+="\r\n";
		m_Text+="        對于E=15的冪模運算可分解為6個乘模運算";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    歸納分析以上方法可以發現對于任意E,可采用以下算法計算D=C**E % N:";
		m_Text+="\r\n";
		m_Text+="    D=1";
		m_Text+="\r\n";
		m_Text+="    WHILE E>=0";
		m_Text+="\r\n";
		m_Text+="      IF E為奇數";
		m_Text+="\r\n";
		m_Text+="        D=D*C % N";
		m_Text+="\r\n";
		m_Text+="        D=D*D % N";
		m_Text+="\r\n";
		m_Text+="        E=E-1";
		m_Text+="\r\n";
		m_Text+="      IF E為偶數";
		m_Text+="\r\n";
		m_Text+="        D=D*D % N";
		m_Text+="\r\n";
		m_Text+="        E=E/2";
		m_Text+="\r\n";
		m_Text+="    RETURN D";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    再加以分析會發現,要知道D 何時需乘 C,不需要反復對E 進行減一或除二的操";
		m_Text+="\r\n";
		m_Text+="作,只需要驗證E 的二進制各位是0 還是1 就可以了,而且從左至右驗證和從右至左";
		m_Text+="\r\n";
		m_Text+="驗證都行,反而從左至右驗證更簡單:";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    若E=Sum[i=0 to n](E[i]*2**i),0<=E[i]<=1";
		m_Text+="\r\n";
		m_Text+="    D=1";
		m_Text+="\r\n";
		m_Text+="    FOR i=n TO 0";
		m_Text+="\r\n";
		m_Text+="      D=D*D % N";
		m_Text+="\r\n";
		m_Text+="      IF E[i]=1";
		m_Text+="\r\n";
		m_Text+="        D=D*C % N";
		m_Text+="\r\n";
		m_Text+="    RETURN D";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    剩下的問題就是乘模運算了,對于A*B % N,如果A、B 都是1024位的大數,先計";
		m_Text+="\r\n";
		m_Text+="算A*B,再% N,就會產生2048位的中間結果,如果不采用動態內存分配技術就必須將";
		m_Text+="\r\n";
		m_Text+="大數定義中的數組空間增加一倍,這樣會造成大量的浪費,因為在絕大多數情況下不";
		m_Text+="\r\n";
		m_Text+="會用到那額外的一倍空間,而采用動態內存分配技術會使大數存儲失去連續性而使運";
		m_Text+="\r\n";
		m_Text+="算過程中的循環操作變得非常繁瑣。所以計算的首要原則就是要避免計算A*B。";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    由于:";
		m_Text+="\r\n";
		m_Text+="        A*B=A*(Sum[i=0 to n](B[i]*0x100000000**i))";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    所以:";
		m_Text+="\r\n";
		m_Text+="        A*B % N = (Sum[i=0 to n]((A*B[i])*0x100000000**i)) % N";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    可以用一個循環求得:";
		m_Text+="\r\n";
		m_Text+="    C=0;";
		m_Text+="\r\n";
		m_Text+="    FOR i=0 to n";
		m_Text+="\r\n";
		m_Text+="      C=C+A*B[i]*0x100000000 % N";
		m_Text+="\r\n";
		m_Text+="    RETURN C";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    事實上,有一種蒙哥馬利算法能夠更快地完成多次循環的乘模運算,但是其原理";
		m_Text+="\r\n";
		m_Text+="涉及較多的數論知識,且實現起來比較麻煩,對速度雖有提高,經測試也不會超過一";
		m_Text+="\r\n";
		m_Text+="個數量級,所以暫且不予考慮。";
		m_Text+="\r\n";
		m_Text+="\r\n";
        m_Edit.SetWindowText(m_Text);
		break;
	case 10:
        m_Text="";
		m_Text+="\r\n";
		m_Text+="    數論學家利用費馬小定理研究出了多種素數測試方法,目前最快的算法是拉賓米";
		m_Text+="\r\n";
		m_Text+="勒測試算法,其過程如下:";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="(1)計算奇數M,使得N=(2**r)*M+1";
		m_Text+="\r\n";
		m_Text+="(2)選擇隨機數A<N";
		m_Text+="\r\n";
		m_Text+="(3)對于任意i<r,若A**((2**i)*M) MOD N = N-1,則N通過隨機數A的測試";
		m_Text+="\r\n";
		m_Text+="(4)或者,若A**M MOD N = 1,則N通過隨機數A的測試";
		m_Text+="\r\n";
		m_Text+="(5)讓A取不同的值對N進行5次測試,若全部通過則判定N為素數";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    若N 通過一次測試,則N 不是素數的概率為 25%,若N 通過t 次測試,則N 不是";
		m_Text+="\r\n";
		m_Text+="素數的概率為1/4**t。事實上取t 為5 時,N 不是素數的概率為 1/128,N 為素數的";
		m_Text+="\r\n";
		m_Text+="概率已經大于99.99%。";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    在實際應用中,可首先用300—500個小素數對N 進行測試,以提高拉賓米勒測試";
		m_Text+="\r\n";
		m_Text+="通過的概率,從而提高測試速度。而在生成隨機素數時,選取的隨機數最好讓 r=0,";
		m_Text+="\r\n";
		m_Text+="則可省去步驟(3) 的測試,進一步提高測試速度。";
		m_Text+="\r\n";
		m_Text+="\r\n";
        m_Edit.SetWindowText(m_Text);
		break;
    case 11:
        m_Text="";
		m_Text+="\r\n";
		m_Text+="    大數的輸入輸出是通過字符串來完成的,事實上很容易實現,例如按照十進制格";
		m_Text+="\r\n";
		m_Text+="式進行處理,則:";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    輸入:";
		m_Text+="\r\n";
		m_Text+="    X=0";
		m_Text+="\r\n";
		m_Text+="    FOR i=0 TO n";
		m_Text+="\r\n";
		m_Text+="      X=X*10";
		m_Text+="\r\n";
		m_Text+="      X=X+(int)(str[n]-48)";
		m_Text+="\r\n";
		m_Text+="    RETURN X";
		m_Text+="\r\n";
		m_Text+="\r\n";
		m_Text+="    輸出:";
		m_Text+="\r\n";
		m_Text+="    str=""";
		m_Text+="\r\n";
		m_Text+="    WHILE(X>0)";
		m_Text+="\r\n";
		m_Text+="      str=(char)(X%10-48)+str";
		m_Text+="\r\n";
		m_Text+="    RETURN str ";
		m_Text+="\r\n";
		m_Text+="\r\n";
        m_Edit.SetWindowText(m_Text);
		break;
	}
	*pResult = 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩久久一区二区| 成人午夜视频免费看| 最新中文字幕一区二区三区| 精品日韩一区二区三区| 日韩午夜中文字幕| 欧美v日韩v国产v| 精品国产一二三| 2020国产精品久久精品美国| 久久精品夜夜夜夜久久| 亚洲国产精品激情在线观看 | 99精品久久99久久久久| 色综合视频一区二区三区高清| 99视频精品在线| 91精彩视频在线| 欧美性受xxxx黑人xyx性爽| 欧美日韩一区小说| 日韩亚洲欧美高清| 久久亚洲一级片| 国产精品人人做人人爽人人添| 亚洲欧美自拍偷拍| 亚洲图片欧美视频| 久久国产精品区| 成人国产精品免费网站| 欧美羞羞免费网站| 欧美精品一区二区不卡| 日韩理论片中文av| 久久国产婷婷国产香蕉| gogo大胆日本视频一区| 欧美精品色一区二区三区| 精品88久久久久88久久久 | 成人手机在线视频| 色悠悠久久综合| 日韩欧美国产一区二区在线播放| 久久久久国产精品人| 国产精品国产三级国产a| 日韩专区中文字幕一区二区| 国产成人鲁色资源国产91色综| 色综合天天综合色综合av| 欧美一区二区三区在| 亚洲欧美日韩成人高清在线一区| 五月婷婷欧美视频| 成人综合婷婷国产精品久久蜜臀| 欧美人牲a欧美精品| 国产精品亲子伦对白| 视频在线观看91| 国产专区欧美精品| 欧美一区二区三区在线视频| 日韩理论片在线| 国产成a人亚洲| 91精品婷婷国产综合久久竹菊| 中文字幕国产一区二区| 国内成人免费视频| 欧美日韩三级在线| 亚洲欧洲精品天堂一级| 国产一区二区精品在线观看| 在线成人高清不卡| 亚洲人成在线播放网站岛国| 久久国产免费看| 91精品国产日韩91久久久久久| 亚洲综合免费观看高清完整版 | 亚洲国产精品久久久久婷婷884| 国产精品一区专区| 日韩欧美黄色影院| 亚洲国产精品久久人人爱 | 欧美刺激脚交jootjob| 亚洲狠狠爱一区二区三区| 91国产成人在线| 亚洲男人的天堂网| 成人av免费网站| 中文字幕成人在线观看| 国产高清不卡一区二区| ww亚洲ww在线观看国产| 韩国视频一区二区| 日韩美女主播在线视频一区二区三区| 亚洲丰满少妇videoshd| 欧美情侣在线播放| 婷婷综合五月天| 欧美一级片在线观看| 日韩av电影天堂| 91精品国产欧美日韩| 日本不卡一区二区三区| 51精品久久久久久久蜜臀| 日本不卡不码高清免费观看| 91精品在线观看入口| 韩国av一区二区| 国产精品欧美一区二区三区| 91在线视频18| 亚洲福利电影网| 91精品福利在线一区二区三区 | 在线观看区一区二| 亚洲国产精品久久久久婷婷884| 欧美高清视频不卡网| 美女脱光内衣内裤视频久久影院| 日韩情涩欧美日韩视频| 国产一区二区三区免费播放 | 性做久久久久久久免费看| 欧美男女性生活在线直播观看| 免费看黄色91| 中文字幕成人网| 在线免费观看视频一区| 日韩va亚洲va欧美va久久| 国产亚洲美州欧州综合国| 91在线观看地址| 日韩和欧美的一区| 久久精品夜色噜噜亚洲aⅴ| 日本高清成人免费播放| 久久精品国内一区二区三区| 日韩毛片精品高清免费| 日韩女优av电影| 99久久夜色精品国产网站| 视频在线观看国产精品| 国产精品天美传媒| 在线播放/欧美激情| 成人免费毛片aaaaa**| 五月激情综合色| 国产精品免费看片| 欧美精品久久99| 97精品久久久久中文字幕| 理论片日本一区| 亚洲女与黑人做爰| 久久蜜桃av一区二区天堂| 欧美网站大全在线观看| 白白色 亚洲乱淫| 国内成+人亚洲+欧美+综合在线| 亚洲精品福利视频网站| 国产拍欧美日韩视频二区| 91精品国产色综合久久不卡蜜臀 | www.av亚洲| 青青草国产精品97视觉盛宴| 亚洲免费观看高清在线观看| 久久综合中文字幕| 91精品蜜臀在线一区尤物| 日本精品视频一区二区| 成人av在线播放网址| 国内精品写真在线观看| 日本女人一区二区三区| 亚洲午夜电影网| 一区二区三区在线视频观看58| 亚洲国产精品成人综合| 久久众筹精品私拍模特| 91精品欧美综合在线观看最新| 欧美亚洲一区二区在线| 91搞黄在线观看| 99精品久久只有精品| av在线免费不卡| kk眼镜猥琐国模调教系列一区二区| 国产一区二区三区不卡在线观看| 老司机午夜精品| 久久精品噜噜噜成人88aⅴ| 青草国产精品久久久久久| 日韩av电影天堂| 久久精品国产99| 国产资源在线一区| 国产成人亚洲综合a∨猫咪| 国产一区999| 色综合激情久久| 色婷婷久久99综合精品jk白丝| 91在线视频官网| 欧美三级日韩三级国产三级| 欧美年轻男男videosbes| 69久久夜色精品国产69蝌蚪网| 91 com成人网| 日韩欧美久久久| 久久精品一区二区三区四区| 国产精品伦理一区二区| 亚洲欧美经典视频| 五月开心婷婷久久| 国产一区二区三区四区在线观看| 成人黄色综合网站| 99精品视频一区| 欧美精品第1页| 久久久777精品电影网影网| 中文字幕一区二区5566日韩| 亚洲图片欧美色图| 精品无人码麻豆乱码1区2区| 国产成人精品三级麻豆| 色8久久人人97超碰香蕉987| 欧美精选午夜久久久乱码6080| 精品欧美一区二区三区精品久久| 久久久不卡网国产精品一区| 中文字幕制服丝袜成人av | 国产精品国模大尺度视频| 亚洲精品欧美在线| 美女视频黄a大片欧美| jvid福利写真一区二区三区| 欧美伊人久久久久久久久影院| 欧美一区二区三区免费大片 | 一区二区三区在线观看视频| 午夜精品免费在线观看| 国产精品91一区二区| 欧美系列一区二区| 久久精品在这里| 无码av免费一区二区三区试看| 国产不卡视频在线观看| 欧美亚洲一区二区在线观看| 国产女人水真多18毛片18精品视频| 一区二区三区中文字幕在线观看| 久久99蜜桃精品| 欧美唯美清纯偷拍| 亚洲欧洲日本在线|