




下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
實(shí)驗(yàn)三:動(dòng)態(tài)規(guī)劃法【實(shí)驗(yàn)?zāi)康摹繎?yīng)用動(dòng)態(tài)規(guī)劃算法思想求解矩陣連乘的順序問題?!緦?shí)驗(yàn)性質(zhì)】驗(yàn)證性實(shí)驗(yàn)?!緦?shí)驗(yàn)要求】應(yīng)用動(dòng)態(tài)規(guī)劃算法的最優(yōu)子結(jié)構(gòu)性質(zhì)和子問題重疊性質(zhì)求解此問題。分析動(dòng)態(tài)規(guī)劃算法的基本思想,應(yīng)用動(dòng)態(tài)規(guī)劃策略寫出算法及相應(yīng)的程序,求解此題。要讀懂讀透A[i,j],A[1,n]=A[1,k]×A[k+1,n],m[i][j],s[i][j]各式所表達(dá)的含義并正確加以應(yīng)用。m[i][j]的遞歸定義:0(i=j)m[i][j]=min{m[i][k]+m[k+1][j]+ni-1nknj(i<j)要求完成:⑴算法描述⑵寫出程序代碼⑶完成調(diào)試⑷進(jìn)行過程與結(jié)果分析?!緦?shí)驗(yàn)內(nèi)容】對(duì)于下列所描述的問題,給出相應(yīng)的算法描述,并完成程序?qū)崿F(xiàn)與時(shí)間復(fù)雜度的分析。該問題描述為:一般地,考慮矩陣A1,A2,…,An的連乘積,它們的維數(shù)分別為d0,d1,…,dn,即Ai的維數(shù)為di-1×di(1≤i≤n)。確定這n個(gè)矩陣的乘積結(jié)合次序,使所需的總乘法次數(shù)最少。對(duì)應(yīng)于乘法次數(shù)最少的乘積結(jié)合次序?yàn)檫@n個(gè)矩陣的最優(yōu)連乘積次序。按給定的一組測(cè)試數(shù)據(jù)對(duì)根據(jù)算法設(shè)計(jì)的程序進(jìn)行調(diào)試:6個(gè)矩陣連乘積A=A1×A2×A3×A4×A5×A6,各矩陣的維數(shù)分別為:A1:10×20,A2:20×25,A3:25×15,A4:15×5,A5:5×10,A6:10×25。完成測(cè)試?!菊{(diào)試分析和心得體會(huì)】運(yùn)行依算法寫出的程序并分析算法實(shí)現(xiàn)的時(shí)間復(fù)雜度情況。#include<iostream.h>#include<iomanip.h>classMatrixChain{public: MatrixChain(intmSize,int*q);//構(gòu)造函數(shù) ~MatrixChain(){} //析構(gòu)函數(shù) intMChain(); //動(dòng)態(tài)規(guī)劃法求解// intLookupChain(); //備忘錄法 voidTraceback(); //構(gòu)造最優(yōu)解的公有函數(shù) voiddisplay(); //顯示private: voidTraceback(inti,intj); //構(gòu)造最優(yōu)解的私有遞歸// intLookupChain(inti,intj); //備忘錄的私有遞歸 int*p,**m,**s,n;};MatrixChain::MatrixChain(intmSize,int*q){ n=mSize; p=q; m=newint*[10];//二維數(shù)組初始化 for(inti=0;i<10;i++)m[i]=newint[10]; s=newint*[10]; //二維數(shù)組初始化 for(intj=0;j<10;j++)s[j]=newint[10];}intMatrixChain::MChain()//求A[0:N-1]的最優(yōu)解{ for(inti=0;i<n;i++) { m[i][i]=0;//初始化 s[i][i]=0; } for(intr=2;r<=n;r++) for(inti=0;i<=n-r;i++) { intj=i+r-1; m[i][j]=m[i+1][j]+p[i]*p[i+1]*p[j+1]; s[i][j]=i; for(intk=i+1;k<j;k++) { intt=m[i][k]+m[k+1][j]+p[i]*p[k+1]*p[j+1]; if(t<m[i][j]) { m[i][j]=t; s[i][j]=k; } } } returnm[0][n-1];}voidMatrixChain::Traceback(inti,intj){ if(i==j) { cout<<"A"<<i; return; } if(i<s[i][j]) cout<<"("; Traceback(i,s[i][j]); if(i<s[i][j]) cout<<")"; if(s[i][j]+1<j) cout<<"("; Traceback(s[i][j]+1,j); if(s[i][j]+1<j) cout<<")";}voidMatrixChain::Traceback(){ cout<<"("; Traceback(0,n-1);//遞歸調(diào)用 cout<<")";}/*intMatrixChain::LookupChain(inti,intj)//備忘錄法實(shí)現(xiàn){ if(m[i][j]>0) returnm[i][j]; if(i==j) return0; intu; u=LookupChain(i+1,j)+p[i]*p[i+1]*p[j+1]; s[i][j]=i; for(intk=i+1;k<j;k++) { intt; t=LookupChain(i,k)+LookupChain(k+1,j)+p[i]*p[k+1]*p[j+1]; if(t<u) { u=t; s[i][j]=k; } } m[i][j]=u; returnu;}intMatrixChain::LookupChain(){ returnLookupChain(0,n-1);}*/voidMatrixChain::display(){ cout<<endl<<"矩陣連乘A[i:j]所需的最少數(shù)乘次數(shù)m[i][j]:"<<endl; for(inti=0;i<n;i++) { cout<<endl; for(intj=0;j<n;j++) if(j<i) cout<<""; else cout<<m[i][j]<<""; } cout<<endl<<"矩陣連乘A[i:j]所需的最少數(shù)乘次數(shù)斷點(diǎn)s[i][j]:"<<endl; for(i=0;i<n;i++) { cout<<endl; for(intj=0;j<n;j++) if(j<i) cout<<""; else cout<<s[i][j]<
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 移動(dòng)支付平臺(tái)技術(shù)解決方案合同
- 智能體育平臺(tái)開發(fā)合同
- 承攬合同終止協(xié)議書
- 平房賣房合同協(xié)議書
- 房屋戶主對(duì)換協(xié)議書
- 技術(shù)合伙合同協(xié)議書
- 店鋪技術(shù)入股協(xié)議書
- 承包檔口經(jīng)營(yíng)協(xié)議書
- 異地編制分手協(xié)議書
- 承包責(zé)任合同協(xié)議書
- 活性炭濾池的設(shè)計(jì)計(jì)算
- JGT334-2012 建筑外墻用鋁蜂窩復(fù)合板
- 個(gè)體防護(hù)裝備PPE重要性課件
- 圖紙會(huì)審記錄表格
- 量子力學(xué)主要知識(shí)點(diǎn)復(fù)習(xí)資料
- 如何編制過程流程圖、PFMEA、控制計(jì)劃文件
- 湖南省2023年跨地區(qū)普通高等學(xué)校對(duì)口招生第一次聯(lián)考(語(yǔ)文對(duì)口)參考答案
- 液化石油氣充裝操作規(guī)程
- 初中《道德與法治》課堂有效教學(xué)的建構(gòu)、實(shí)施與創(chuàng)新
- 供應(yīng)鏈公司成立方案
- 質(zhì)量風(fēng)險(xiǎn)與機(jī)遇分析評(píng)價(jià)表完整
評(píng)論
0/150
提交評(píng)論