動(dòng)態(tài)規(guī)劃矩陣連乘_第1頁
動(dòng)態(tài)規(guī)劃矩陣連乘_第2頁
動(dòng)態(tài)規(guī)劃矩陣連乘_第3頁
動(dòng)態(tài)規(guī)劃矩陣連乘_第4頁
動(dòng)態(tài)規(guī)劃矩陣連乘_第5頁
全文預(yù)覽已結(jié)束

下載本文檔

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

文檔簡介

實(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)連乘積次序。按給定的一組測試數(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。完成測試?!菊{(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)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論