動態(tài)規(guī)劃算法(共10頁)_第1頁
動態(tài)規(guī)劃算法(共10頁)_第2頁
動態(tài)規(guī)劃算法(共10頁)_第3頁
動態(tài)規(guī)劃算法(共10頁)_第4頁
動態(tài)規(guī)劃算法(共10頁)_第5頁
已閱讀5頁,還剩5頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)

文檔簡介

1、精選優(yōu)質(zhì)文檔-傾情為你奉上實驗02動態(tài)規(guī)劃算法實驗?zāi)康?. 掌握動態(tài)規(guī)劃算法的基本方法2. 掌握動態(tài)規(guī)劃算法中最優(yōu)子結(jié)構(gòu)的分析3. 掌握遞歸求解最優(yōu)值的方法4. 掌握最優(yōu)解的構(gòu)造.預(yù)習(xí)要求1. 認(rèn)真閱讀算法設(shè)計教材,了解動態(tài)規(guī)劃原理;2. 設(shè)計用動態(tài)規(guī)劃算法求解矩陣連乘、最長公共子序列以及電路布線的java程序.實驗題1. 給定n個矩陣A1, A2, ,An,其中,Ai與Ai+1是可乘的,計算這n個矩陣的連乘積。從中找出一種乘次數(shù)最少的計算次序。2. 給定2個序列X=x1,x2,xm和Y=y1,y2,yn,找出X和Y的最長公共子序列。3. 在一塊電路板的上、下2端分別有n個接線柱。根據(jù)電路設(shè)計

2、,要求用導(dǎo)線(i,(i)將上端接線柱與下端接線柱相連,確定將哪些連線安排在第一層上,使得該層上有盡可能多的連線。該問題要求確定導(dǎo)線集Nets=(i,(i),1in的最大不相交子集。 實驗步驟1. 設(shè)計并實現(xiàn)算法并準(zhǔn)備測試用例,修改并調(diào)試程序,直至正確為止;2. 應(yīng)用設(shè)計的算法和程序求解問題;3. 將程序整理成功能模塊存盤備用. 實驗報告要求1. 闡述實驗?zāi)康暮蛯嶒瀮?nèi)容;2. 闡述求解問題的算法原理;3. 提交實驗程序的功能模塊;4. 記錄最終測試數(shù)據(jù)和測試結(jié)果。參考1./矩陣連乘類public class Matrix private int MN;/表示矩陣鏈中矩陣的數(shù)目private in

3、t p;/存放各個矩陣的維數(shù)private int A;/存放要進行連乘的多個矩陣private int m;/用來存放Ai到Aj的最少乘次數(shù)private int s;/用來存放Ai到Aj的最后斷開位置/public Matrix()MN=0;p=new int MN;/構(gòu)造函數(shù),L為矩陣的數(shù)目public Matrix(int L)MN=L;p=new int MN+1;A=new int MN;m=new int MN+1MN+1;s=new int MN+1MN+1;/隨機生成連乘矩陣的維數(shù)1-11for(int i=0;i<=MN;i+)pi=(int) Math.round(

4、Math.random()*10)+1;/隨機生成各個矩陣for(int i=0;i<MN;i+)Ai=new int pipi+1;CreatMatrix(Ai,pi,pi+1);/創(chuàng)建矩陣a,維數(shù)為m*nprivate void CreatMatrix(int a,int m,int n)for(int i=0;i<m;i+)for(int j=0;j<n;j+)aij=(int) Math.round(Math.random()*99)-50;/輸出連乘的所有矩陣private void printAllM()for (int i=0;i<this.MN;i+)S

5、ystem.out.println("A"+(i+1)+": "+Ai.length +"*"+Ai0.length );printM(Ai);/輸出矩陣a的每個元素private void printM(int a)for(int i=0;i<a.length ;i+)System.out.print(" ");for(int j=0;j<ai.length;j+)System.out.print(String.format("%4d", aij);System.out.print

6、ln();public static void main(String args)Matrix M=new Matrix(7);M.printAllM();M.matrixChain(M.p,M.m,M.s);System.out.print("矩陣鏈所需的最少乘次數(shù)為:"+M.m1M.MN);System.out.println();String s=new StringM.MN+1;for(int i=1;i<=M.MN;i+)si="A"+i;M.traceback(M.s, 1, M.MN,s);for(int i=1;i<=M.MN

7、;i+)System.out.print(si);/作用:計算a,b矩陣的乘積,將結(jié)果保存在c中,/參數(shù):ra為a的行數(shù),ca為a的列數(shù),rb為b的行數(shù),cb為b的列數(shù)public static void matrixMultiply(int a,int b,int c,int ra,int ca,int rb,int cb)if(ca!=rb)throw new IllegalArgumentException("矩陣不可乘");/i為乘積矩陣元素的行下標(biāo)for(int i=0;i<ra;i+)/j為乘積矩陣元素的列下標(biāo)for (int j=0;j<cb;j+

8、)/sum初始化為a中i行第一個原素和b中j列第一個元素的乘積int sum =ai0*b0j;/計算a中第i行和b中第j列對應(yīng)元素乘積的和for(int k=1;k<ca;k+)sum+=aik*bkj;/將乘積的和賦值給乘積矩陣的相應(yīng)元素cij=sum;/作用:計算矩陣連乘時,矩陣鏈的最少乘次數(shù)/參數(shù):p0:n表示矩陣A1,A2.An的維數(shù)。Ai為pi-1*pi/ m,用來存放矩陣鏈的最少乘次數(shù),mij表示Ai,j最少乘次數(shù)/ s,用來存放矩陣鏈最優(yōu)次序的斷開位置。public static void matrixChain(int p, int m, int s)/n為矩陣個數(shù)in

9、t n=p.length-1;/矩陣鏈長度為1,不需要進行乘運算,即mii值為0for (int i=1;i<=n;i+) mii=0;/計算矩陣鏈長度大于1的m值for (int r=2;r<=n;r+)/針對長度為r的各個矩陣鏈Ai,j計算最少乘次數(shù)mfor(int i=1;i<=n-r+1;i+) int j=i+r-1;/計算初始值mij=mii+mi+1j+pi-1*pi*pjmij=mi+1j+pi-1*pi*pj;/記錄對應(yīng)的斷開位置isij=i;/斷開位置k從i+1到j(luò)-1,依次計算m值for (int k=i+1; k<j; k+)/計算斷開位置為k的

10、乘計算次數(shù),保存到tint t=mik+mk+1j+pi-1*pk*pj;/若t比所記錄的最少乘計算次數(shù)少,則用t替換,并記錄新的斷開位置if (t<mij) mij=t;sij=k;public static void traceback(int s,int i,int j,String c)if(i=j) return;traceback(s,i,sij,c);traceback(s,sij+1,j,c);ci="("+ci;cj=cj+")"System.out.println("Multiply A"+i+",

11、"+sij+"and A"+(sij+1)+","+j);2./最長公共子序列類public class Xl private char x;private char y;private int xl;private int yl;public Xl(int m,int n)xl=m;yl=n;x=new char xl;y=new char yl;for(int i=0;i<m;i+)int t=(int)(Math.random()*8)+65;xi=(char) t;for(int i=0;i<n;i+)int t=(int)

12、(Math.random()*8)+65;yi=(char) t;private void print()for(int i=0;i<this.xl;i+)System.out.print(String.format("%3s", xi);System.out.println();for(int i=0;i<this.yl;i+)System.out.print(String.format("%3s", yi);public static void main(String args)Xl xl1=new Xl(10,12);int b=new

13、 int xl1.xlxl1.yl;int lcsl=lcsLength(xl1.x,xl1.y,b);xl1.print();System.out.println();System.out.print("最長公共子序列的長度為:"+lcsl);System.out.println();xl1.lcs(xl1.xl-1,xl1.yl-1,xl1.x, b);/計算x和y最長公共子序列的長度,b用來記錄標(biāo)記/最優(yōu)值存放在c中public static int lcsLength(char x,char y,int b)int m=x.length-1;int n=y.leng

14、th-1;int c=new int m+1n+1;/j=0,最長公共子序列為0for(int i=1;i<= m;i+) ci0=0;/i=0,最長公共子序列為0for(int i=1;i<= n;i+) c0i=0;/i,j>0時,計算最長公共子序列的長度for(int i=1;i<= m;i+) for (int j=1;j<=n;j+)/xi=yj,cij=ci-1j-1+1if (xi=yj) cij=ci-1j-1+1;bij=1;/xi<>yj,cij=maxcij-1,ci-1jelse if (ci-1j>=cij-1) cij

15、=ci-1j;bij=2;else cij=cij-1;bij=3; return cmn;/構(gòu)造最長公共子序列public static void lcs(int i,int j,char x,int b)if (i =0 | j=0) return;if (bij= 1)lcs(i-1,j-1,x,b);System.out.print(String.format("%3s", xi);else if (bij= 2) lcs(i-1,j,x,b);else lcs(i,j-1,x,b);./電路步線public class WireSet private int n;

16、/導(dǎo)線的數(shù)目private int m;private int c;/存放導(dǎo)線private int size;private int net;/存放最大公共不相交子集/構(gòu)造函數(shù):根據(jù)num的值所表示的導(dǎo)線的數(shù)目,進行初始化public WireSet(int num)n=num;c=new int n+1;size=new int n+1n+1;net=new int n+1;/對c進行賦初值,為1-n的任一個排列c1=(int)(Math.random()*(n)+1);int i=2;while(i<=n)int f=0;int t=(int)(Math.random()*(n)+

17、1);for(int j=1;j<i;j+)if (cj=t) f=1;break;if (f=0)ci=t;i+;/用來輸出相關(guān)信息public void print()/輸出上端線路編號System.out.print("上端線路編號:");for(int i=0;i<=n;i+)System.out.print(String.format("%3d", i);System.out.println();System.out.println();/輸出下端線路編號System.out.print("下端線路編號:");f

18、or(int i=0;i<=n;i+)System.out.print(String.format("%3d", ci);System.out.println();/輸出最大不相交子集的個數(shù)System.out.print("最大不相交子集的大小為:"+sizenn);System.out.println();/輸出最大不相交子集中的各個導(dǎo)線System.out.print("上端線路編號:");for(int i=this.m-1;i>=0;i-)System.out.print(String.format("%3d", i);System.out.println();System.out.print("下端線路編號:");for(int i=this.m-1;i>=0;i-)System.out.print(String.format("%3d", ci);public static void main(String args)WireSet ws= new WireSet(10);/計算最優(yōu)值ws.mnset(ws

溫馨提示

  • 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論