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

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

?? rsahelpdlg.cpp

?? 非對稱密碼系統,包含RSA,ECC,大數乘法。
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
		m_Text+="  C=Sum[i=0 to q](A*B[i]*0x100000000**i)";
		m_Text+="\r\n";
		m_Text+="  而(A*B[i]*100000000**i)=Sum[j=0 to p](A[j]*B[i]*0x100000000**(i+j))";
		m_Text+="\r\n";
		m_Text+="  所以C=Sum[i=0 to q](Sum[j=0 to p](A[j]*B[i]*0x100000000**(i+j)))";
		m_Text+="\r\n";
		m_Text+="";
		m_Text+="\r\n";
		m_Text+="因此:";
		m_Text+="\r\n";
		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_HelpRsa.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_HelpRsa.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_HelpRsa.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_HelpRsa.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_HelpRsa.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_HelpRsa.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_HelpRsa.SetWindowText(m_Text);
		break;
	}
	*pResult = 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久免费视频一区| 欧美一区二区三区视频在线观看| 久久蜜桃av一区二区天堂| 久久精品国内一区二区三区| 日韩精品专区在线| 高清国产一区二区| 亚洲欧美视频在线观看| 欧美综合一区二区三区| 日韩国产欧美三级| 久久综合色综合88| www.一区二区| 午夜欧美在线一二页| 精品国产99国产精品| 成人午夜短视频| 亚洲国产精品一区二区www在线| 欧美乱妇一区二区三区不卡视频| 琪琪久久久久日韩精品| 国产亲近乱来精品视频| 欧美亚洲愉拍一区二区| 久久国产精品色| 亚洲视频 欧洲视频| 91精品国产色综合久久不卡电影 | 亚洲欧洲一区二区在线播放| 色就色 综合激情| 精品亚洲免费视频| 亚洲欧美在线高清| 日韩午夜激情av| av亚洲精华国产精华精| 人禽交欧美网站| 亚洲欧美偷拍卡通变态| 日韩写真欧美这视频| 成人免费av网站| 裸体在线国模精品偷拍| 亚洲裸体xxx| 久久亚洲综合av| 欧美日韩国产成人在线免费| 成人精品电影在线观看| 理论电影国产精品| 亚洲国产视频一区| 中文一区二区完整视频在线观看 | 欧美一区二区三区成人| 成人动漫视频在线| 精品一区二区三区在线播放| 一区二区三区精品久久久| 久久综合久久99| 欧美精品丝袜久久久中文字幕| jlzzjlzz亚洲日本少妇| 精品一区精品二区高清| 午夜免费欧美电影| 一区二区三区四区乱视频| 日本一区二区三区高清不卡| 欧美一卡2卡三卡4卡5免费| 91久久一区二区| 国产精品123区| 韩国欧美国产1区| 男男成人高潮片免费网站| 亚洲国产精品久久人人爱蜜臀| 中文字幕制服丝袜一区二区三区| 久久久午夜精品| 日韩欧美国产综合在线一区二区三区| 欧美在线观看你懂的| 91丝袜呻吟高潮美腿白嫩在线观看| 国产老妇另类xxxxx| 久久精品99国产精品日本| 亚洲成人av电影在线| 亚洲免费三区一区二区| 1区2区3区国产精品| 国产精品免费免费| 国产精品女同互慰在线看 | 中文字幕一区二区三区四区不卡 | 久久婷婷一区二区三区| 日韩亚洲欧美在线| 欧美一级理论片| 精品日韩在线一区| 精品久久久久久久久久久久包黑料| 日韩一区二区电影网| 欧美一级电影网站| 日韩欧美一卡二卡| 精品国产免费久久| 久久久噜噜噜久噜久久综合| 久久精品夜夜夜夜久久| 日本一二三四高清不卡| 国产精品乱码人人做人人爱| 国产精品私房写真福利视频| 亚洲国产精品99久久久久久久久| 国产亚洲1区2区3区| 国产精品素人一区二区| 亚洲人成在线播放网站岛国| 亚洲综合视频在线| 日韩精品每日更新| 韩国女主播一区| av在线免费不卡| 色婷婷精品久久二区二区蜜臂av| 欧美主播一区二区三区| 欧美精品精品一区| 26uuu色噜噜精品一区二区| 欧美国产精品中文字幕| 一区二区三区欧美亚洲| 日韩av高清在线观看| 国产在线精品一区二区| 9久草视频在线视频精品| 在线免费观看日本欧美| 日韩三级.com| 国产精品三级视频| 午夜婷婷国产麻豆精品| 精品在线观看免费| www.欧美精品一二区| 一本久道久久综合中文字幕| 91麻豆精品国产91久久久使用方法 | 一区二区在线观看视频在线观看| 性久久久久久久久久久久| 久久国产福利国产秒拍| bt7086福利一区国产| 欧美亚洲一区三区| 久久尤物电影视频在线观看| 亚洲精品va在线观看| 精品一区二区免费| 99久久er热在这里只有精品15| 欧美色爱综合网| 亚洲国产精品黑人久久久| 天天综合网 天天综合色| 国产大陆亚洲精品国产| 欧美午夜电影在线播放| 国产亚洲精久久久久久| 香蕉影视欧美成人| 不卡影院免费观看| 欧美一级高清大全免费观看| 亚洲日本一区二区| 国产美女精品在线| 欧美老肥妇做.爰bbww视频| 中文av字幕一区| 精品亚洲国内自在自线福利| 欧美三级日韩三级| 国产精品久久久久婷婷二区次| 日韩二区三区四区| 在线免费观看不卡av| 国产精品嫩草影院av蜜臀| 蜜臀精品久久久久久蜜臀| 色就色 综合激情| 中文一区二区完整视频在线观看| 麻豆国产精品一区二区三区 | 欧美日韩一区精品| 亚洲欧美韩国综合色| 国产suv精品一区二区三区| 正在播放一区二区| 亚洲午夜精品网| 91丝袜国产在线播放| 中文字幕不卡在线观看| 久久电影国产免费久久电影| 欧美精品vⅰdeose4hd| 亚洲一级二级三级在线免费观看| 成人一级黄色片| 久久免费的精品国产v∧| 美女久久久精品| 欧美一级艳片视频免费观看| 亚洲午夜激情网站| 在线亚洲人成电影网站色www| 欧美国产一区二区| 国产a级毛片一区| 久久久综合视频| 国产老肥熟一区二区三区| 26uuu久久天堂性欧美| 九九热在线视频观看这里只有精品| 制服丝袜成人动漫| 日韩成人免费电影| 91精品国产一区二区三区| 日产国产欧美视频一区精品| 5566中文字幕一区二区电影| 日精品一区二区三区| 欧美一区二区三区男人的天堂| 偷拍一区二区三区四区| 91精品婷婷国产综合久久性色| 男女男精品网站| 精品国产91洋老外米糕| 国产精品中文字幕日韩精品 | 欧美视频中文一区二区三区在线观看| 亚洲美女电影在线| 欧美在线你懂得| 日韩1区2区3区| 精品不卡在线视频| 国产精品综合网| 国产精品你懂的| 欧美性大战xxxxx久久久| 天堂成人免费av电影一区| 欧美电影免费观看高清完整版在线 | 91福利社在线观看| 午夜精品福利在线| 日韩亚洲欧美综合| 国产精品一区在线| 成人欧美一区二区三区白人 | 欧美三级蜜桃2在线观看| 视频一区中文字幕国产| 日韩欧美一二三| 国产ts人妖一区二区| 亚洲永久免费av| 久久蜜桃av一区二区天堂 | 国产精品美女久久久久aⅴ| 91久久国产最好的精华液| 亚洲r级在线视频| xnxx国产精品|