版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
大數(shù)相乘畢業(yè)論文大數(shù)相乘畢業(yè)論文/大數(shù)相乘畢業(yè)論文摘要大整數(shù)乘法運(yùn)算經(jīng)常會(huì)遇到溢出或精度不夠的問題,而在許多領(lǐng)域要求高精度大整數(shù)運(yùn)算。因而,有很多人在這方面作過努力。大整數(shù)運(yùn)算比較通用的方法有疊加法(小學(xué)生乘法)和分治法。疊加法與我們筆算乘法一樣,用第一個(gè)數(shù)的每一位去乘第二個(gè)數(shù)的每一位,然后把運(yùn)算結(jié)果按權(quán)值疊加;分治法是把大整數(shù)化為可直接運(yùn)算的小整數(shù),再進(jìn)行乘法運(yùn)算,最后把乘得的結(jié)果組合為所求結(jié)果。本文在總結(jié)這兩種方法的基礎(chǔ)上,提出一種把疊加與分治相結(jié)合的方法——疊加分治法。疊加分治法吸收了疊加法和分治算法的優(yōu)點(diǎn)。該算法基于分治思想,把大整數(shù)分解成較小整數(shù)(幾十位),再用疊加法運(yùn)算較小整數(shù),最后把運(yùn)算結(jié)果組合為所求的積。一方面,減少較小整數(shù)多次分解與組合帶來的在時(shí)間上和空間上的開銷;另一方面,避免大整數(shù)疊加運(yùn)算在時(shí)間上與規(guī)模成級(jí)數(shù)增加開銷。最后,本文還設(shè)計(jì)了一個(gè)算法演示程序,對(duì)分治算法、疊加算法與本文提出的疊加分治法做出定量分析,并就它們的優(yōu)劣和適用環(huán)境做出詳盡闡述。關(guān)鍵詞大整數(shù)、乘法、分治法、疊加法、疊加分治法AbstractMultiplicationoflargeintegersusuallymeetstheproblemofoverflowingornotenoughaccurate.But,inmanyappliedrealms,highlyaccuratecalculationoflargeintegersisrequested.Asaresult,manypeoplehavemadegreateffortsinthisaspect.Now,thegeneralmethodsarethepen-and-pencilmethodandthedivide-and-conquermethod.Thepen-and-pencilmethod,whichissimilartomultiplywithapen,ismultiplyinglargeintegerswitheverydigitofonenumberbyeverydigitoftheotherone.Differently,thedivide-and-conquermethodistodividelargeintegersintoseveralsmallerintegers(generally,theyaretow),andthen,tocarryonthemultiplicationofthesmallerintegers.Thistextspecifiesanotheralgorithm,whichbasesonthosetwomethods.Thisalgorithm,thatcombinesthepen-and-pencilmethodandthedivide-and-conquermethodtogether,iscalledthecombinativealgorithmofpen-and-pencilanddivide-and-conquer.Itisthecombinationofvirtuesofthepen-and-pencilmethodandthedivide-and-conquermethod.Itsthought,basedonthedivide-and-conquer,isfirstlyusingthedivide-and-conquermethodtodividethelargeintegersintosmallerintegers(severaldozendigits),nextusingthepen-and-pencilmethodtocalculatethesmallerintegers,andthencombiningthecalculatinglyresultsintothedesiredproduct.Ontheonehand,itreducesthetimeexpenseondecomposingsmallerintegersandcombiningtheirproduct.Ontheotherhand,itavoidsthefleetlyincrementalexpenseontimethatcomesfromtheincrementaldigitsoflargeintegers.Lastly,thistextanalyzesthepen-and-pencilmethod,thedivide-and-conquermethod,andthecombinationofpen-and-pencilanddivide-and-conquerquantificationally,andthen,elaboratestheirgoodandbad,andtheirappliedenvironments.Keywordslargeintegers,multiplication,pen-and-pencil,divide-and-conquer,combinativealgorithmofpen-and-pencilanddivide-and-conquer目錄摘要 IAbstract II第1章緒論 11.1課題背景 11.2發(fā)展?fàn)顩r 11.3各章安排 2第2章算法設(shè)計(jì) 32.1疊加法 32.2分治法 52.2.1分治法思想簡(jiǎn)介 52.2.2用分治法設(shè)計(jì)大整數(shù)乘法 72.3疊加分治法 9第3章算法演示設(shè)計(jì) 113.1概要設(shè)計(jì) 113.2詳細(xì)設(shè)計(jì) 123.2.1主調(diào)用模塊設(shè)計(jì) 123.2.2疊加法模塊設(shè)計(jì) 133.2.3疊加分治法模塊設(shè)計(jì) 153.3結(jié)果與分析 17結(jié)論 19參考文獻(xiàn) 20附錄英譯漢 21F1Divide-and-ConquerandMultiplicationofLargeIntegers 21F1.1Divide-and-Conquer 21F1.2MultiplicationofLargeIntegers 23F2分治與大整數(shù)乘法 26F2.1分治 26F2.2大整數(shù)乘法 28致謝 31緒論課題背景密碼學(xué)是用來保證信息安全的一種必要的手段,是信息安全的一個(gè)核心。密碼學(xué)要解決的問題也是信息安全的主要任務(wù),就是解決網(wǎng)上信息的機(jī)密性、完整性、不可否認(rèn)性和可用性。機(jī)密性就是要傳送一個(gè)信息,這個(gè)信息只有接收者才能讀到,其他的人,其他的用戶是無法獲取這個(gè)信息,即使得到加密以后的形式,也無法打開信息內(nèi)容。機(jī)密性就是要對(duì)傳送的信息加密,保證信息不泄漏給未經(jīng)授權(quán)的人。完整性就是防止信息被未經(jīng)授權(quán)的人篡改,保證信息不被篡改,而且信息的完整性跟不可否認(rèn)性是緊密相連的東西。不可否認(rèn)性和完整性這兩條實(shí)際上都是一種對(duì)信息的一些認(rèn)證,就是對(duì)每一條消息,它是可以通過密碼算法加密,用像數(shù)字簽名一類的認(rèn)證算法進(jìn)行識(shí)別和認(rèn)證??捎眯援?dāng)然意思比較明確,就是保證信息與信息系統(tǒng)確實(shí)為授權(quán)使用者所用[10]。密碼學(xué)必然包括一些直接的數(shù)學(xué)理論,很多數(shù)學(xué)理論對(duì)密碼學(xué)都有直接的應(yīng)用,如橢圓曲線群中的離散對(duì)數(shù)問題、整數(shù)分解問題、丟番圖算法。而這些數(shù)學(xué)理論在計(jì)算機(jī)中的實(shí)現(xiàn),大都涉與到大整數(shù)的運(yùn)算。這里所謂的大整數(shù)指的是至少上百位之間的數(shù)字組成的大整數(shù)。比如RSA、Rabin、以與EIGamal等加密機(jī)制都需要這種大整數(shù)的運(yùn)算。而現(xiàn)有的計(jì)算機(jī)一般只能處理32位的二進(jìn)制整數(shù),少數(shù)的可以處理64位整數(shù)。因此,大整數(shù)的運(yùn)算就必須借助軟件才能實(shí)現(xiàn)。發(fā)展?fàn)顩r任何一個(gè)可以用計(jì)算機(jī)求解的問題所需的計(jì)算時(shí)間都與其規(guī)模n有關(guān)。問題的規(guī)模越小,越容易直接求解,解題所需的計(jì)算時(shí)間也越少。例如,對(duì)于n個(gè)元素的排序問題,當(dāng)n=1時(shí),不需任何計(jì)算;n=2時(shí),只要作一次比較即可排好序;n=3時(shí)只要作3次比較即可,…。而當(dāng)n較大時(shí),問題也就不那么容易處理。為了加快大整數(shù)乘法運(yùn)算,人們對(duì)大整數(shù)乘法的運(yùn)算與實(shí)現(xiàn)進(jìn)行了很多研究。目前,大整數(shù)的運(yùn)算方法主要有將大整數(shù)運(yùn)算分解成規(guī)模較小整數(shù)運(yùn)算的分治算法和整體運(yùn)算的疊加算法。參考文獻(xiàn)[1,2,3]給出了基于小學(xué)生乘法的疊加算法。該思想是把大整數(shù)按位分解成整數(shù),然后分別相乘,再按權(quán)值疊加得到所乘的積。參考文獻(xiàn)[4,5,6]給出了基于大整數(shù)化為小整數(shù)的分治法。它把大整數(shù)分解成兩個(gè)規(guī)模較小的、計(jì)算機(jī)可直接處理的整數(shù),讓小整數(shù)相乘,然后在把它們的乘積組合起來,得到所需的大整數(shù)之積。前者思路簡(jiǎn)單,易于實(shí)現(xiàn);但時(shí)間復(fù)雜度高,隨著規(guī)模增大,時(shí)間花費(fèi)增加很快。后者隨著規(guī)模增大,時(shí)間花消增大比例不如疊加法大;但是當(dāng)整數(shù)規(guī)模較小時(shí),用于分解與合并花費(fèi)的時(shí)間占總運(yùn)算時(shí)間的比例很大。所以本文提出一種把疊加與分治相結(jié)合的方法。它首先把大整數(shù)分解成規(guī)模較小的整數(shù),再用疊加法計(jì)算較小整數(shù)的值,最后把計(jì)算結(jié)果組合為所求的原整數(shù)的解。各章安排第一章:緒論。主要介紹大整數(shù)乘法的應(yīng)用領(lǐng)域和當(dāng)前發(fā)展?fàn)顩r。第二章:詳細(xì)描述疊加法、分治法和疊加分治算法的設(shè)計(jì)思想。第三章:基于VB,設(shè)計(jì)演示程序,演示以上三種算法。算法設(shè)計(jì)疊加法疊加算法就是通用的筆算算法思想。在兩個(gè)大整數(shù)相乘中,它用第一個(gè)數(shù)的每一位去乘第二個(gè)數(shù)的每一位,再把運(yùn)算結(jié)果按權(quán)值疊加,進(jìn)位處理后,得到所求的結(jié)果。具體描述如下文所示。將因數(shù)和表示如下:,則和可以記為:,因此,大整數(shù)乘法的計(jì)算公式為:………(2.1)在本文中,為了方便起見,將的結(jié)果稱為部分積,將、稱為部分因子。根據(jù)公式(2.1),大整數(shù)疊加算法的計(jì)算過程如圖2.1所示。從圖2.1可知,這種算法的思想是:按照部分積的權(quán)值從低到高的順序,每次計(jì)算出所有權(quán)值為的部分積,同時(shí)完成它們之間的累加,然后再計(jì)算權(quán)值更高的部分積,依次類推,直到計(jì)算出所有的部分積。圖2.1中,是權(quán)值為的部分積的累加之和,其計(jì)算方法如公式(2.2)所示:………(2.2)圖2.1疊加法大整數(shù)乘法算法根據(jù)圖2.1所描述的算法思想,得到如下偽代碼描述的算法:FunctionMult(X,Y){//X和Y是記錄兩個(gè)整數(shù)的數(shù)組,返回結(jié)果為X和Y的乘積XYFor(i=1;i<len(x);i++)//乘積疊加運(yùn)算For(j=1;j<len(y);j++)R(i+j-1)+=X(i)*Y(j)For(i=1;i<len(x)+len(y);i++)R(i)向R(i+1)進(jìn)位ReturnR}//Mult算法2.1由公式(2.1)得,疊加算法共做次乘法。由2.1.1節(jié)和圖2.1知,該算法還需做次加法運(yùn)算和次進(jìn)位處理。在計(jì)算時(shí)間主要由乘法決定的情況下,它的時(shí)間復(fù)雜度為:………………(2.3) 又根據(jù)圖2.1,存儲(chǔ)和分別花費(fèi)單元,存儲(chǔ)積需要個(gè)單元,因此該算法的空間復(fù)雜度為:………………(2.4)分治法分治法思想簡(jiǎn)介分治法的設(shè)計(jì)思想是,將一個(gè)難以直接解決的大問題,分割成一些規(guī)模較小的相同問題,以便各個(gè)擊破,分而治之。1、分治法所能解決的問題一般具有以下幾個(gè)特征[5]:(1)該問題的規(guī)??s小到一定的程度就可以容易地解決;(2)該問題可以分解為若干個(gè)規(guī)模較小的相同問題,即該問題具有最優(yōu)子結(jié)構(gòu)性質(zhì);(3)利用該問題分解出的子問題的解可以合并為該問題的解;(4)該問題所分解出的各個(gè)子問題是相互獨(dú)立的,即子問題之間不包含公共的子問題。
上述的第一條特征是絕大多數(shù)問題都可以滿足的,因?yàn)閱栴}的計(jì)算復(fù)雜性一般是隨著問題規(guī)模的增加而增加;第二條特征是應(yīng)用分治法的前提,它也是大多數(shù)問題可以滿足的,此特征反映了遞歸思想的應(yīng)用;第三條特征是關(guān)鍵,能否利用分治法完全取決于問題是否具有第三條特征,如果具備了第一條和第二條特征,而不具備第三條特征,則可以考慮貪心法或動(dòng)態(tài)規(guī)劃法。第四條特征涉與到分治法的效率,如果各子問題是不獨(dú)立的,則分治法要做許多不必要的工作,重復(fù)地解公共的子問題。2、分治法的基本步驟[6]如圖2.2所示,分治法在每一層遞歸上都有三個(gè)步驟:解答子問題解答子問題1解答子問題2規(guī)模為的問題規(guī)模為的子問題1規(guī)模為的子問題2合并為原問題的解圖2.2分治技術(shù)(典型實(shí)例)(1)分解:將原問題分解為若干個(gè)規(guī)模較小,相互獨(dú)立,與原問題形式相同的子問題;(2)解決:若子問題規(guī)模較小而容易被解決則直接解,否則遞歸地解各個(gè)子問題;(3)合并:將各個(gè)子問題的解合并為原問題的解。它的一般的算法設(shè)計(jì)模式如下:Divide-and-Conquer(P){if|P|≤n0
thenreturn(ADHOC(P))將P分解為較小的子問題P1、P2、…、Pkfori←1tok
{do
yi←Divide-and-Conquer(Pi)//遞歸解決Pi}T←MERGE(y1,y2,…,yk)//合并子問題Return(T)}算法2.2其中|P|表示問題P的規(guī)模;為一閾值,表示當(dāng)問題P的規(guī)模不超過時(shí),問題已容易解出,不必再繼續(xù)分解。ADHOC(P)是該分治法中的基本子算法,用于直接解小規(guī)模的問題P。因此,當(dāng)P的規(guī)模不超過時(shí),直接用算法ADHOC(P)求解。算法MERGE(y1,y2,…,yk)是該分治法中的合并子算法,用于將P的子問題P1、P2、…、Pk的相應(yīng)的解y1、y2、…、yk合并為P的解。根據(jù)分治法的分割原則,原問題應(yīng)該分為多少個(gè)子問題才較適宜?各個(gè)子問題的規(guī)模應(yīng)該怎樣才為適當(dāng)?這些問題很難予以肯定的回答。但從大量實(shí)踐中發(fā)現(xiàn),在用分治法設(shè)計(jì)算法時(shí),最好使子問題的規(guī)模大致相同。換句話說,將一個(gè)問題分成大小相等的k個(gè)子問題的處理方法是行之有效的。許多問題可以取k=2。這種使子問題規(guī)模大致相等的做法是出自一種平衡子問題的思想,它幾乎總是比子問題規(guī)模不等的做法要好。分治法的合并步驟是算法的關(guān)鍵所在。有些問題的合并方法比較明顯,有些問題合并方法比較復(fù)雜,或者是有多種合并方案;或者是合并方案不明顯。究竟應(yīng)該怎樣合并,沒有統(tǒng)一的模式,需要具體問題具體分析。用分治法設(shè)計(jì)大整數(shù)乘法明顯地,如果用經(jīng)典的小學(xué)生乘法計(jì)算兩個(gè)位數(shù)的大整數(shù),將需要做次乘法運(yùn)算。似乎不可能有一種算法能使乘法運(yùn)算次數(shù)少于,但事實(shí)證明并非如此。分治法就是一個(gè)明顯的例子。設(shè)和都是位的進(jìn)制整數(shù),現(xiàn)在要計(jì)算它們的乘積。將和分別分為2段,每段的長(zhǎng)為位(為簡(jiǎn)單起見,假設(shè)是2的冪),如圖2.3所示。圖2.3大整數(shù)和的分段由此,,。這樣,和的乘積為:…(2.5)如果按照公式(2.5)計(jì)算,則我們必須進(jìn)行4次位整數(shù)的乘法(,,和),以與3次不超過位的整數(shù)加法(分別對(duì)應(yīng)于公式(2.1)中的加號(hào)),此外還要做2次進(jìn)位處理(分別對(duì)應(yīng)于公式(2.5)中乘和乘)。所有這些加法和進(jìn)位共用步運(yùn)算。設(shè)是2個(gè)n位整數(shù)相乘所需的運(yùn)算總數(shù),由公式(2.5),則有:………(2.6)由此可得。要想改進(jìn)算法的計(jì)算復(fù)雜性,必須減少乘法次數(shù)。為此我們把XY寫成另一種形式:………(2.7)雖然公式(2.7)看起來比公式(2.5)要復(fù)雜些,但它僅需做3次位整數(shù)的乘法(,和),6次加、減法和2次進(jìn)位。由此可得:….………(2.8)用解遞歸方程的套用公式法,可得其解為:………………(2.9)由此可見,改用分治法做大整數(shù)乘法,從理論上講,效率有明顯提高。根據(jù)以上描述的思想,得出大整數(shù)相乘的偽代碼算法MULT,如下所示:FunctionMULT(X,Y,n){//X和Y為2個(gè)小于n位的無符號(hào)整數(shù),返回結(jié)果為X和Y的乘積XYif(n=1)return(X*Y)else{A=X的左邊n/2位:B=X的右邊n/2位C=Y的左邊n/2位:D=Y的右邊n/2位ml=MULT(A,C,n/2)m2=MULT(A-B,D-C,n/2)m3=MULT(B,D,n/2)S=S*(m1左移2n位+(m1+m2+m3)左移n位+m3)return(S)}}//MULT算法2.3公式(2.9)已經(jīng)給出分治算法的時(shí)間復(fù)雜度,現(xiàn)在只討論該算法的空間復(fù)雜度。由公式(2.7)可以看出,存儲(chǔ)、需要個(gè)單元格,存儲(chǔ)、A、B、C、D需要個(gè)單元格,存儲(chǔ)和需要個(gè)單元格。由此可得,X乘以Y需要存儲(chǔ)空間:….……(2.10)用解遞歸方程的套用公式法,可得其解為:………………(2.11) 于是,用分治法實(shí)現(xiàn)大整數(shù)相乘的時(shí)間復(fù)雜度為,空間復(fù)雜度為。疊加分治法由2.1節(jié)和2.2節(jié)對(duì)疊加法和分治法的描述與其效率的分析可知,在理論上講,分治法的時(shí)間效率要高于疊加法。但是,在實(shí)際上并非如此[6]。當(dāng)整數(shù)位數(shù)很?。ㄈ缥粩?shù)小于600)時(shí),分治法的效率反而不如疊加法。這是因?yàn)榉种畏ㄔ诜指詈秃喜⑦^程中要消耗掉大量的時(shí)間,規(guī)模越小,分割合并所占的時(shí)間比例越大。試想,用另一種方法。既可以避免疊加法在運(yùn)算過程中因規(guī)模增大,時(shí)間復(fù)雜度以增大;又可以避免因分治法分得過細(xì)而帶來的分割組合時(shí)間的大量增加。這就是本文要提出的疊加分治法。疊加分治法是用分治思想,把超大整數(shù)分割成較小整數(shù)(一般在30位左右),再用疊加法計(jì)算較小整數(shù)的積,最后合并為超大整數(shù)的積。疊加分治法的偽代碼描述如下所示:FunctionMULT(X,Y,n){//X和Y為2個(gè)n位的無符號(hào)整數(shù),返回結(jié)果為X和Y的乘積XYif(n<=LL){//LL為分割上限,當(dāng)乘數(shù)的規(guī)模小于LL,不再分割,調(diào)用疊加運(yùn)算ReturnPen-and-Pencil(X,Y)//用疊加法計(jì)算X,Y的積}else{A=X的左邊n/2位B=X的右邊n/2位C=Y的左邊n/2位D=Y的右邊n/2位ml=MULT(A,C,n/2)m2=MULT(A-B,D-C,n/2)m3=MULT(B,D,n/2)S=(m1左移2n位+(m1+m2+m3)左移n位+m3)return(S)}}算法2.4算法演示設(shè)計(jì)為證明第二章所提出的疊加分治算法性能的高效性,本章在VB平臺(tái)下設(shè)計(jì)了一個(gè)演示程序。概要設(shè)計(jì)為證明本文提出的疊加分治算法性能的高效性,需要用不同的方法對(duì)同一對(duì)大整數(shù)做乘法運(yùn)算。因此本演示程序需要完成四個(gè)方面的功能:分治實(shí)現(xiàn)大整數(shù)乘法運(yùn)算、疊加實(shí)現(xiàn)大整數(shù)乘法運(yùn)算、疊加分治實(shí)現(xiàn)大整數(shù)乘法運(yùn)算以與它們的效率與結(jié)果的比較。當(dāng)用疊加分治法實(shí)現(xiàn)且分治上限變?yōu)?時(shí),疊加分治法就退化為分治法。因此,該演示程序大致可以分為三個(gè)模塊:主調(diào)用模塊、疊加算法模塊、疊加分治與分治共用模塊,如圖3.1所示。演示程序疊加算法模塊疊加算法模塊主調(diào)用模塊疊加分治及分治共用模塊息圖3.1模塊關(guān)系圖現(xiàn)在對(duì)這三個(gè)的功能模塊做概括說明:主調(diào)用模塊:實(shí)現(xiàn)調(diào)用疊加算法模塊、疊加分治與分治共用模塊和比較運(yùn)算結(jié)果的正確性。疊加算法模塊:完成對(duì)大整數(shù)的疊加運(yùn)算。疊加分治與分治共用模塊:完成對(duì)大整數(shù)的分治運(yùn)算和疊加分治運(yùn)算。詳細(xì)設(shè)計(jì)主調(diào)用模塊設(shè)計(jì)1、設(shè)計(jì)界面,如圖3.2所示:圖3.2主調(diào)用模塊界面2、主界面窗體與其控件屬性設(shè)置表3.1主界面窗體與其控件的屬性對(duì)象功能屬性設(shè)計(jì)時(shí)屬性值說明Form3程序運(yùn)行主界面Caption大整數(shù)乘法器Command1引導(dǎo)疊加法界面Caption疊加法運(yùn)算器Command2引導(dǎo)疊加分治法界面Caption疊加分治法運(yùn)算器Command3判斷兩種算法計(jì)算結(jié)果是否相等Caption兩種算法計(jì)算結(jié)果相等否3、窗體中主要過程與其代碼的文字簡(jiǎn)述PrivateSubCommand1_Click()Callform.pen-and-pencil‘調(diào)用疊加法模塊EndSubPrivateSubCommand2_Click()Callform.cent‘調(diào)用疊加分治法模塊EndSubPrivateSubCommand3_Click()判斷兩種方法運(yùn)算的結(jié)果是否相等EndSub疊加法模塊設(shè)計(jì)1、疊加算法界面設(shè)計(jì),如圖3.2所示:圖3.2疊加算法模塊界面2、疊加運(yùn)算窗體與其控件屬性設(shè)置表3.2疊加運(yùn)算窗體與其控件的屬性對(duì)象功能屬性設(shè)計(jì)時(shí)屬性值說明Form4用戶界面窗體Caption疊加法用戶界面標(biāo)題Command1調(diào)用運(yùn)算乘積函數(shù)Caption做乘積運(yùn)算命令按鈕標(biāo)題Command2清空輸入輸出口Caption清空命令按鈕標(biāo)題Text1輸入乘數(shù)Text空白MultiLineTrue允許多行輸入ScrollBars2垂直滾動(dòng)條Text2輸入乘數(shù)Text空白MultiLineTrue允許多行輸入ScrollBars2垂直滾動(dòng)條Text3輸出積Text空白MultiLineTrue允許多行輸入ScrollBars2垂直滾動(dòng)條LockedTrue不允許輸入Label1指示輸入位置Caption因數(shù)1Label2指示輸入位置AutoWrapTrue控件可以自動(dòng)調(diào)整Caption因數(shù)2Label3指示輸出位置AutoWrapTrue控件可以自動(dòng)調(diào)整Caption積Label4統(tǒng)計(jì)因數(shù)1的字符長(zhǎng)度AutoWrapTrue控件可以自動(dòng)調(diào)整Caption空Label5統(tǒng)計(jì)因數(shù)2的字符長(zhǎng)度AutoWrapTrue控件可以自動(dòng)調(diào)整Caption空Label6統(tǒng)計(jì)積的字符長(zhǎng)度AutoWrapTrue控件可以自動(dòng)調(diào)整Caption空3、窗體中主要過程與其代碼的文字簡(jiǎn)述PrivateSubCommand1_Click()T=hefa(text1.text,text2.text)‘對(duì)輸入因數(shù)字符串合法性檢查,‘如果合法則返回True;否則,返回Falseif(T)thenxCint(text1.text);yCint(text2.text)‘因數(shù)字符串轉(zhuǎn)化為‘整數(shù)賦值給數(shù)組x、yr疊加運(yùn)算(x,y)‘疊加運(yùn)算x、y賦給rtext3.textCchar(r)‘結(jié)果數(shù)組轉(zhuǎn)化因數(shù)字符串賦值文本3輸出為Else報(bào)錯(cuò)處理EndIfEndSubPrivateSubText1_KeyPress(KeyAsciiAsInteger)控制因數(shù)1的輸入,只有輸入合法才讓輸入文本接受EndSubPrivateSubText2_KeyPress(KeyAsciiAsInteger)控制因數(shù)2的輸入,只有輸入合法才讓輸入文本接受EndSub疊加分治法模塊設(shè)計(jì)1、疊加分治法模塊界面設(shè)計(jì),如圖3.3所示:圖3.3疊加分治法模塊界面2、疊加分治運(yùn)算窗體與其控件屬性設(shè)置表3.3疊加分治運(yùn)算窗體與其控件的屬性對(duì)象功能屬性設(shè)計(jì)時(shí)屬性值說明Form1用戶界面窗體Caption疊加分治法用戶界面標(biāo)題Command1調(diào)用運(yùn)算乘積函數(shù)Caption做乘積運(yùn)算命令按鈕標(biāo)題Command2清空輸入輸出口Caption清空命令按鈕標(biāo)題Text1輸入乘數(shù)Text空白MultiLineTrue允許多行輸入ScrollBars2垂直滾動(dòng)條Text2輸入乘數(shù)Text空白MultiLineTrue允許多行輸入ScrollBars2垂直滾動(dòng)條Text3輸出積Text空白MultiLineTrue允許多行輸入ScrollBars2垂直滾動(dòng)條LockedTrue不允許輸入Text4輸入分治下限Text25默認(rèn)下限Label1指示輸入位置Caption因數(shù)1AutoWrapTrue控件可以自動(dòng)調(diào)整Label2指示輸入位置Caption因數(shù)2AutoWrapTrue控件可以自動(dòng)調(diào)整Label3指示輸出位置Caption積AutoWrapTrue控件可以自動(dòng)調(diào)整Label4統(tǒng)計(jì)因數(shù)1的字符長(zhǎng)度Caption空AutoWrapTrue控件可以自動(dòng)調(diào)整Label5統(tǒng)計(jì)因數(shù)2的字符長(zhǎng)度Caption空AutoWrapTrue控件可以自動(dòng)調(diào)整Label6統(tǒng)計(jì)積的字符長(zhǎng)度Caption空AutoWrapTrue控件可以自動(dòng)調(diào)整Label7記錄程序開始時(shí)間Caption空AutoWrapTrue控件可以自動(dòng)調(diào)整Label8記錄程序結(jié)束時(shí)間Caption空AutoWrapTrue控件可以自動(dòng)調(diào)整Label9提示分治下限Caption分治下限3、窗體中主要過程與其代碼的文字簡(jiǎn)述DimTtimeAsInteger‘記錄分治下限SubMul(x()AsInteger,y()AsInteger,r()AsInteger)Ifx(0)<TtimeThen‘如果位數(shù)小于下限,則調(diào)用疊加法CallPensM(x,y,r)ElseA=left(x,len(x)/2):B=right(x,(len(x)+1)/2)C=left(x,len(y)/2):D=right(x,(len(y)+1)/2)E=A-B:F=C-DCallMul(A,C,r1)CallMul(B,D,r3)CallMul(E,F,r2)EndIfEndSubPrivateSubPensM(x()AsInteger,y()AsInteger,r()AsInteger)DimiAsInteger,jAsIntegerFori=x(0)To1Step-1Forj=y(0)To1Step-1r(i+j)=r(i+j)+x(i)*y(j)NextjNextiEndSubPrivateSubCommand1_Click()T=hefa(text1.text,text2.text,Text4.Text)‘輸入字符串合法性檢查,‘如果合法則返回True;否則,返回Falseif(T)thenTtime=CInt(Text4.Text)xCint(text1.text);yCint(text2.text)‘因數(shù)字符串轉(zhuǎn)化為‘整數(shù)賦值給數(shù)組x、yr疊加分治運(yùn)算(x,y)‘疊加運(yùn)算x、y賦給rtext3.textCchar(r)‘結(jié)果數(shù)組轉(zhuǎn)化因數(shù)字符串從文本3輸出為Else報(bào)錯(cuò)處理EndIfEndSub結(jié)果與分析圖3.4~3.6展示了在VB平臺(tái)上實(shí)現(xiàn)上述三種方法對(duì)兩個(gè)大整數(shù)(都是8192位9)相乘,在時(shí)間效率上的差異??梢钥闯?,用疊加法耗時(shí)2秒(圖3.4),用分治法耗時(shí)8秒(圖3.5),疊加分治法耗時(shí)不到1秒(圖3.6)。通過它們的差異,得出如下結(jié)論:用疊加分治法耗時(shí)最少。因而,疊加分治法是一種效率很高的大整數(shù)乘法運(yùn)算方法。同時(shí),也必須注意:當(dāng)兩乘數(shù)位數(shù)相差很大時(shí),疊加分治法的效率反而不如疊加法的效率。所以當(dāng)兩整數(shù)位數(shù)相差很大時(shí),疊加法的效率可能比疊加分治法的效率更高。圖3.4疊加法運(yùn)算結(jié)果圖3.5分治法運(yùn)算結(jié)果圖3.6疊加分治法運(yùn)算結(jié)果結(jié)論本文以大整數(shù)相乘在計(jì)算機(jī)中的表示為題目,主要討論了三個(gè)方面的問題:疊加法實(shí)現(xiàn)大整數(shù)乘法、分治法實(shí)現(xiàn)大整數(shù)乘法、疊加分治法實(shí)現(xiàn)大整數(shù)乘法。大整數(shù)疊加運(yùn)算是傳統(tǒng)的經(jīng)典算法。在這一部分討論了大整數(shù)的表示方法,大整數(shù)的表示采用數(shù)組的形式,每個(gè)數(shù)組元素存放一位十進(jìn)制整數(shù),以與在這種大整數(shù)的存儲(chǔ)形式下,探討了在密碼學(xué)中經(jīng)常用到的大整數(shù)疊加運(yùn)算方法是如何實(shí)現(xiàn)的。分治法是比較著名的算法思想,分治法實(shí)現(xiàn)大整數(shù)乘法從理論上提高了大整數(shù)乘法運(yùn)算的效率。本部分主要討論了分治法是如何實(shí)現(xiàn)大整數(shù)乘法運(yùn)算的,并對(duì)實(shí)現(xiàn)效率做出定性分析。在用疊加分治法實(shí)現(xiàn)大整數(shù)乘這一部分中,通過分析疊加法、分治法的優(yōu)劣和它們的應(yīng)用環(huán)境,結(jié)合它們的特點(diǎn),提出了把疊加法和分治法相結(jié)合的方法——疊加分治法。在最后一章,做了一個(gè)演示程序,演示了本文提出算法的正確性和高效性,對(duì)三種算法進(jìn)行了定性分析。下一步工作與有待改進(jìn)之處:優(yōu)化算法,進(jìn)一步提高運(yùn)算效率。在現(xiàn)有基礎(chǔ)之上,實(shí)現(xiàn)大整數(shù)的除法運(yùn)算。在大整數(shù)四則混合運(yùn)算基礎(chǔ)上,繼續(xù)進(jìn)行其他有關(guān)模的運(yùn)算算法的研究。參考文獻(xiàn)[1] 原巍,許琪,沈緒榜.大整數(shù)乘法器設(shè)計(jì).微電子學(xué)與計(jì)算機(jī),2003,2003增刊:1-3[2] 羅洋.大整數(shù)乘法的計(jì)算機(jī)處理.遼林師專學(xué)報(bào),2005,第1期:39-40[3] 吳曉麗,吳鋒.計(jì)算機(jī)中的大整數(shù)運(yùn)算技術(shù).武警工程學(xué)院學(xué)報(bào),1999,第15卷第2期:35-37[4] M.H.Alsuwaiyel著,吳偉昶等譯.算法設(shè)計(jì)技巧與分析.北京:電子工業(yè)出版社,2004.[5] 王曉東.算法設(shè)計(jì)與分析.北京:清華大學(xué)出版社,2003.[6] [美]AnanyLevitin.IntroductiontoTheDesignandAnalysisofAlgorithms.北京:清華工業(yè)出版社,2003.[7] 石研,姚晟.大整數(shù)算術(shù)運(yùn)算的實(shí)現(xiàn).安慶師范學(xué)院學(xué)報(bào)(自然科學(xué)版).2004,第10卷第2期:75-77[8] 楊劍等.字符化大整數(shù)運(yùn)算系統(tǒng)的構(gòu)造與實(shí)現(xiàn).揚(yáng)州大學(xué)學(xué)報(bào)(自然科學(xué)版).2000,第3卷第4期:52-56[9] 凌晨,買磊.基于兩種不同存儲(chǔ)方式的大整數(shù)運(yùn)算與性能比較.安慶師范學(xué)院學(xué)報(bào)(自然學(xué)報(bào)).2003,第9期第2版:86-88[10] 李愛武.密碼學(xué)中的大整數(shù)運(yùn)算與其應(yīng)用.[學(xué)位論文].廣州:中山大學(xué),2002[11]余祥宣等.計(jì)算機(jī)算法基礎(chǔ)(第二版).武漢:華中科技大學(xué)出版社,2004[12]周彬.大整數(shù)模運(yùn)算算法研究與實(shí)現(xiàn).[學(xué)位論文].成都:電子科技大學(xué),2001/ruanjiansp/guide/1388.htm附錄英譯漢F1Divide-and-ConquerandMultiplicationofLargeIntegersF1.1Divide-and-ConquerDivide-and-conquerisprobablythebest-knowgeneralalgorithmdesigntechnique.Thoughitsfamemayhavesomethingtodowithitscatchyname,itiswelldeserved:quiteafewefficientalgorithmsarespecificimplementationsofthisgeneralstrategy.Divide-and-conqueralgorithmsworkaccordingtothefollowinggeneralplan:1.Aproblem’sinstanceisdividedintoseveralsmallerinstanceofthesameproblem,ideallyofaboutthesamesize.2.Thesmallerinstancesaresolved(typicallyrecursively,thoughsometimesadifferentalgorithmisemployedwheninstancesbecomesmallenough).3.Ifnecessary,thesolutionsobtainedforthesmallerinstancesarecombinedtogetasolutiontotheoriginalproblem.Thedivide-and-conquertechniqueisdiagrammedinFigure1,whichdepictsthecaseofdividingaproblemintotowsmallersubproblems,byfarthemostwidelyoccurringcase(atlestfordivide-and-conqueralgorithmsdesignedtobeexecutedonasingle-processorcomputer).SSolutiontotheoriginalproblemProblemofsizenSubproblem1ofsizeSubproblem1ofsizeSolutiontosubproblem2Solutiontosubproblem1Figure1Divide-and-conquertechnique(typicalcase)Asanexample,letusconsidertheproblemofcomputingthesimofnumbers.If,wecandividetheproblemintotowinstancesofthesameproblem:tocomputethesumofthefirstnumbersandtocomputethesumoftheremainingnumbers.(Ofcourse,ifwesimplyreturnastheanswer.)Onceeachofthesetowsumsiscomputed(byapplyingthesamemethod,i.e.,recursively),wecanaddtheirvaluestogetthesuminquestion:Isthisanefficientwaytocomputethesumofnumbers?Amomentofreflection(whycoulditbemoreefficientthanthebrute-forcesummation?),asmallexampleofsumming,say,fournumbersbythisalgorithm,aformalanalysis(whichfollows),andcommonsense(wedonotcomputesumsthisway,dowe?)allleadtoanegativeanswertothisquestion.Thus,noteverydivide-and-conqueralgorithmisnecessarilymoreefficientthanevenabrute-forcesolution.ButoftenourprayerstotheGoddessofAlgorithmicsareanswer,andthetimespentonexecutingthedivide-and-conquerplanturnsouttobesmallerthansolvingaproblembyadifferentmethod.Infact,thedivide-and-conquerapproachyieldssomeofthemostimportantandefficientalgorithmsincomputerscience.Wediscussafewclassicexamplesofsuchalgorithmsinthischapter.Thoughweconsideronlysequentialalgorithmshere,itisworthkeepinginmindthatthedivide-and-conquertechniqueisideallysuitedforparallelcomputations,inwhicheachsubprolemcanbesolvedsimultaneouslybyitsownprocessor.Thesumexampleillustratesthemosttypicalcaseofdivide-and-conquer:aproblem’sinstanceofsize.Moregenerally,aninstanceofsizecanbedividedintoseveralinstancesofsize,withofthemneedingtobesolved.(Here,andareconstants;and.)Assumingthatsizeisapowerof,simplifyouranalysis,wegetthefollowingrecurrencefortherunningtime:………..(1)whereisafunctionthataccountsforthetimespentondividingtheproblemintosmalleronesandoncombiningtheirsolutions.(Forthesummationexample,and.)Recurrence(1)iscalledthegeneraldivide-and-conquerrecurrence.Obviously,theorderofgrowthofitssolutiondependsonthevaluesoftheconstantsandandtheorderofgrowthofthefunction.Theefficiencyanalysisofmanydivide-and-conqueralgorithmsisgreatlysimplifiedbythefollowingtheorem.MASTERTHEOREMIfwhereinrecurrenceequation(1),then….……….(2)(Analogousresultsholdfortheandnotations,too)Forexample,therecurrenceequationforthenumberofadditionsmadebythedivide-and-conquersummationalgorithm(seeabove)oninputsofsizeis……………..………..……..(3)Thus,forthisexample,,,and;hence,since,….………….…….………(4)Notethatwewereabletofindthesolution’sefficiencyclasswithoutgoingthroughthedrudgeryofsolvingtherecurrence.But,ofcourse,thisapproachcanonlyestablishasolution’sorderofgrowthtowithinanunknownmultiplicativeconstantwhilesolvingarecurrenceequationwithaspecificinitialconditionyieldsanexactanswer(atlestfor’sthatarepowerof).F1.2MultiplicationofLargeIntegersSomeapplications,notablymoderncryptology,requiremanipulationofintegersthatareover100decimaldigitslong.Obviously,suchintegersaretoolongtofitinasinglewordofamoderncomputer,andhencetheyrequirespecialtreatment.Thispracticalneedsupportsinvestigationsofalgorithmsforefficientmanipulationoflargeintegers.Inthissection,weoutlineaninterestingalgorithmformultiplyingsuchnumbers.Obviously,ifweusetheclassicpen-and-pencilalgorithmformultiplyingtow-digitintegers,eachofthedigitsofthefirstnumbersismultipliedbyeachofthedigitsofthesecondnumberforthetotalofdigitmultiplications.(Ifoneofthenumbershasfewerdigitsthantheother,wecanpadashorternumberwithleadingzerostoequaltheirlengths.)Thoughitmightappearthatitwouldbeimpossibletodesignanalgorithmwithfewerthandigitmultiplications,itprovesnottobethecase.Themiracleofdivide-and-conquercomestotherescuetoaccomplishthisfeat.Todemonstratethebasicideaofthealgorithm,letusstartwithacaseoftow-digitintegers,23and14.Thesenumberscanberepresentedasfollows:andNowletusmultiplythem:Thelastformulayieldsthecorrectanswerof322,ofcourse,butitusesthesamefourdigitmultiplicationsasthepen-and-pencilalgorithm.Fortunately,wecancomputethemiddletermwithjustonedigitmultiplicationbytakingadvantageoftheproducts()andthatneedtobecomputedanyway:Ofcourse,thereisnothingspecialaboutthenumberswejustmultiplied.Foranypairoftow-digitnumbersand,theirproductcanbecomputedbytheformulawhereistheproductoftheirfirstdigitsistheproductoftheirseconddigitsistheproductofthesumofthe’sdigitsandthesumofthe’sdigitsminusthesumofand.Nowweapplythistricktomultiplyingtow-digitintegersandwhereisapositiveevennumber.Letusdividebothnumbersinthemiddle—afterall,wepromisedtotakeadvantageofthedivide-and-conquertechnique.Wedenotethefirsthalfofthe’sdigitsbyandthesecondhalfby;for,thenotionsareand,respectively.Inthesenotions,impliesthatandimpliesthat.Therefore,takingadvantageofthesametrickweusedfortow-digitnumbers,wegetwhereistheproductoftheirfirsthalvesistheproductoftheirsecondhalvesistheproductofthesumofthe’shalvesandthesumofthe’shalvesminusthesumofand.Ifiseven,wecanapplythesamemethodforcomputingtheproducts,and.Thus,ifisapowerof2,wehavearecursivealgorithmforcomputingtheproductoftow-digitintegers.Initspureform,therecursionisstoppedwhenbecomesone.Itcanalsobestoppedwhenwedeemsmallenoughtomultiplythenumbersone.Itcanalsobestoppedwhenwedeemsmallenoughtomultiplythenumbersofthatsizedirectly.Howmanydigitmultiplicationsdoesthisalgorithmmake?Sincemultiplicationof-digitnumbersrequiresthreemultiplicationsof-digitnumbers,therecurrenceforthenumberofmultiplicationswillbeSolvingitbybackwardsubstitutionsforyieldsSince(Onthelaststep,wetakeadvantageofthefollowingpropertyoflogarithms:)Youshouldkeepinmindthatformoderatelylargeintegersthisalgorithmwillprobablyrunlongertheclassicone.BrassardandBratley([BB96],pp.70-71)reportthatintheirexperimentsthedivide-and-conqueralgorithmstartedtooutperformthepen-and-pencilmethodonintegersover600digitslong.Ifyouprograminanobject-orientedlanguagesuchasJava,C++,orSma
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 婚慶行業(yè)前臺(tái)工作總結(jié)
- 定制家具設(shè)計(jì)師工作要點(diǎn)
- 《美麗的海洋世界》課件
- 購(gòu)物服務(wù)員工作總結(jié)
- 前臺(tái)文員情緒智力提升方案計(jì)劃
- 《苗木霜害怎么預(yù)防》課件
- 2024年廣東省汕尾市公開招聘警務(wù)輔助人員輔警筆試自考題2卷含答案
- 2021年甘肅省嘉峪關(guān)市公開招聘警務(wù)輔助人員輔警筆試自考題2卷含答案
- 2023年四川省雅安市公開招聘警務(wù)輔助人員輔警筆試自考題1卷含答案
- 2021年云南省楚雄自治州公開招聘警務(wù)輔助人員輔警筆試自考題1卷含答案
- 培智三年級(jí)上冊(cè)生活語文期末測(cè)試卷(A)
- GB/T 13296-2023鍋爐、熱交換器用不銹鋼無縫鋼管
- JCT2381-2016 修補(bǔ)砂漿標(biāo)準(zhǔn)
- 新加坡學(xué)習(xí)匯報(bào)
- 人工智能與機(jī)器學(xué)習(xí)基礎(chǔ)課程
- 辦公大樓物業(yè)服務(wù)投標(biāo)方案(完整技術(shù)標(biāo))
- 高速公路隧道工程施工方案
- 中國(guó)營(yíng)養(yǎng)科學(xué)全書
- 針灸推拿試題(附參考答案)
- 《機(jī)械制圖》說課課件-畫組合體視圖的方法和步驟
- 2023-2024學(xué)年成都市錦江區(qū)四年級(jí)數(shù)學(xué)第一學(xué)期期末統(tǒng)考模擬試題含答案
評(píng)論
0/150
提交評(píng)論