



下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
分治法大數(shù)乘法書上講述的2個位數(shù)為n位的數(shù)乘,我這里擴(kuò)展一下,寫一個更為般的方法任意位數(shù)的2個數(shù)乘:對于任意位的個相乘ab,寫成:a=*+a0-----n1為位b=b1*10^(n2/2)+b0-----n2為位分治策略就基于以上換,將a,寫成前半數(shù)字和后一半數(shù)字相的形式,如若a=,那a1=,a0=3678(意若不是偶數(shù)截取較小一半)這樣a和b相乘就以寫為:a*b={a1*10^(n1/2)+a0}*{b110^(n2/2)+b0展開后整理:a*b=a1*b1*10^[(n1+n2)/2]+a1*b0*10^(n1/2)+a0*b1*10^(n2/2)+a0*b0四項這就容遞的求a*,果嫌解的還大,可繼分。你可以自己規(guī)定在何結(jié)束遞歸實現(xiàn)方法:們定義一支持方法Mul(Strings1,String,于在結(jié)束歸時(在例中,我定義有一數(shù)是位結(jié)束遞歸直接用普乘法)計兩個字符串的乘積(為了表示大數(shù)用字符串來受參數(shù))有了這個持方法,分治遞歸實現(xiàn)兩個大數(shù)乘的實現(xiàn)如:staticMutiply(Stringa,Stringb)字符串讀入個大整數(shù){result=0;if==1==//歸結(jié)束的條件={
//果2字符串的長度都>=2a1=/2);符串(較短的一半)
//取前一半的字a0=a.substring(a1.length(),a.length());//取后一半的字符串//;//;b1=b.substring(0,b.length()/2);b0=b.substring(b1.length(),b.length());//治的思想將整數(shù)寫成這樣:a1*10^(n1/2)=*
,相乘展開得到以下四項//中,為個整數(shù)a,的位數(shù)=)*a0.length()b0.length())Mutiply(a1,b0)*+*Math.pow(10,}}可以看到如我們個符串都大1位,那么我們就繼續(xù)分ab完整的代碼測試的例:packageSection4;;/*第4章分治法
大整數(shù)乘法--計算2個大整數(shù)的乘積*/BigIntegerMutiply{/***@paramargs*/staticmain(String[]args){//TODOmethoda=;=s1"";s2=a*b;result=Mutiply(s1,s2);""result);result);}statica,Stringb)//用字符串讀2大整數(shù){result=0;
if==1==//歸結(jié)束的條件={
//果2字符串的長度都>=2a1=/2);符串(較短的一半)
//取前一半的字a0=a.substring(a1.length(),a.length());//取后一半的字符串//;//;b1=b.substring(0,b.length()/2);b0=b.substring(b1.length(),b.length());//治的思想將整數(shù)寫成這樣:a1*10^(n1/2)=*,相乘展開得到以下四項//中,為個整數(shù)a,的位數(shù)=)*a0.length()b0.length())Mutiply(a1,b0)*+*Math.pow(10,}}privatestaticlongMul(Strings1,Strings2){//算2字符串表示的大整數(shù)的乘積//際上只有當(dāng)一個字符串的長度為時,這個函數(shù)才會被調(diào)用int[]a=newintint[]b=newintfor(i0;i<
//放大整數(shù)s1的各位//放大整數(shù)s2的各位//將字符i'轉(zhuǎn)化為整數(shù)i放入整數(shù)數(shù)組a[i]=(ints1.charAt(i)-48;for(i0;i<b[i]=(ints2.charAt(i)-48;num1toNum(a);num2toNum(b);num1*
}privatestaticlongtoNum([]a){//一個整數(shù)的位數(shù)組轉(zhuǎn)化為它對應(yīng)的數(shù)result=0;for(i0;i<=result*10+//;}}和903923的乘:true注意寫這算法僅僅看看分治怎樣實現(xiàn)的,的測試用例也算不上是整數(shù)真正的大數(shù)在普通的算機(jī)上會出,計算出來些研人的驗示在于的數(shù)乘,治略性才過普的法顯然,這大的數(shù)字在常規(guī)的計算機(jī)上無法運算。擴(kuò)展一點,整數(shù)加法么做?----------大數(shù)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 抹灰合同抹灰合同協(xié)議
- 個人裝修泥工合同
- 弱電安全文明施工方案
- 茶山社區(qū)消毒施工方案
- 法律邏輯與案例解析試題集
- 環(huán)境工程水處理技術(shù)知識考核卷
- 學(xué)校雇傭保安服務(wù)合同
- 樹木涂白劑施工方案
- 新建道路施工方案
- 干掛巖棉板的施工方案
- 高中學(xué)生社會實踐活動100例
- 2023年新改版教科版六年級下冊科學(xué)全冊教案(新課標(biāo))
- 天津漁港防波堤施工組織設(shè)計
- 03SG520-2 實腹式鋼吊車梁(中輕級工作制 A1~A5 Q345鋼 跨度6m,7.5m,9m)
- Access數(shù)據(jù)庫程序設(shè)計上機(jī)操作練習(xí)題2
- 《最優(yōu)化方法》復(fù)習(xí)題(含答案)
- 設(shè)施草莓栽培技術(shù)(大棚草莓)PPT
- 博科ERP產(chǎn)品介紹
- 丙醇安全技術(shù)說明書MSDS
- GB/T 4506-1984針尖鋒利度和強(qiáng)度試驗方法
- GB/T 11864-2008船用軸流通風(fēng)機(jī)
評論
0/150
提交評論