版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
動(dòng)態(tài)規(guī)劃為了解決一類最優(yōu)化問題通過求得所有子問題的最優(yōu)解來得到最終問題的最優(yōu)解動(dòng)態(tài)規(guī)劃狀態(tài)狀態(tài)轉(zhuǎn)移方程初始條件動(dòng)態(tài)規(guī)劃的基本要素狀態(tài)是一維的F[i]由F[j](j<i)得到初始條件F[0]或F[1]Part1線性動(dòng)態(tài)規(guī)劃設(shè)有整數(shù)序列b1,b2,b3,…,bm,若存在下標(biāo)i1<i2<i3<…<in,且bi1<bi2<bi3<…<bin,則稱b1,b2,b3,…,bm中有長度為n的上升序列bi1,
bi2,bi3,…,bin
。求最長上升序列的長度N求長度為N的上升序列的個(gè)數(shù)求本質(zhì)不同的長度為N的上升序列的個(gè)數(shù)N<=1000例1.最長上升序列狀態(tài):F[i]表示以b[i]結(jié)尾的最長上升序列長度轉(zhuǎn)移方程:F[i]=max(F[j]+1),j<I,b[j]<b[i]初始條件:F[i]=1,1<=i<=NT[i]表示以b[i]結(jié)尾的序列長度為F[i]的方案數(shù)T[i]=sigma(T[j]),F[i]=F[j]+1,B[i]>B[j]初始條件:T[i]=1SolutionP[i]表示上身序列長度為i的序列末尾元素的最小值當(dāng)計(jì)算F[i]時(shí),二分j,滿足P[j]<B[i]F[i]=F[j]+1P[F[i]]=min(P[F[i]],B[i])時(shí)間復(fù)雜度:O(NlogN)LISO(NlogN)算法考慮一個(gè)由N個(gè)整數(shù)構(gòu)成的數(shù)列,其中1到N都在數(shù)列中出現(xiàn)了恰好一次。在這個(gè)數(shù)列中從左到右任取兩個(gè)數(shù),如果前者比后者大,那么這對(duì)數(shù)就是一個(gè)逆序?qū)?。而整個(gè)數(shù)列的逆序數(shù)就是其中所有逆序?qū)Φ目倲?shù)。例如,數(shù)列(1,4,3,2)的逆序數(shù)為3,因?yàn)榇嬖谌齻€(gè)逆序?qū)Γ海?,3),(4,2)和(3,2)。寫一個(gè)程序,計(jì)算有多少長度為N的這種數(shù)列,使它的逆序數(shù)恰為C。N<=1000,C<=10000例2.zbrka狀態(tài):F[i][j]表示1~i的一個(gè)排列,逆序?qū)?shù)目為j的方案數(shù)枚舉1的位置F[i][j]=sigma(F[i-1][j-k]),0<=k<=i-1時(shí)間復(fù)雜度:O(N*N*C)空間復(fù)雜度:O(N*C)Solution如圖,已知一個(gè)有向圖,求一條從最左邊的點(diǎn)走到最右邊點(diǎn)的方案(只能從左往右走),使得所經(jīng)過的權(quán)值和除以4的余數(shù)最小。例3.Mod4余數(shù)最小問題狀態(tài):F[i]表示到點(diǎn)i的最小值轉(zhuǎn)移:F[i]=min((F[j]+num[i])mod4),j到i有邊樣例就出現(xiàn)bugQuestions局部最優(yōu)解不能保證全局最優(yōu)解本題不符合最優(yōu)化性質(zhì)F[i][j]表示到點(diǎn)i余數(shù)為j是否可行求出所有x=(F[k][p]+num[i])%4,F[i][x]=trueSolution狀態(tài)有兩維或者多維F[i][j]表示i~j這個(gè)區(qū)間的最優(yōu)值F[i-1][j],F[i][j-1]F[i][j]F[i][k]+F[k][j]F[i][j]
Part2.區(qū)間動(dòng)態(tài)規(guī)劃在一園形操場四周擺放N堆石子(N≤100),現(xiàn)要將石子有次序地合并成一堆.規(guī)定每次只能選相臨的兩堆合并成一堆,并將新的一堆的石子數(shù),記為該次合并的得分。編一程序,由文件讀入堆數(shù)N及每堆石子數(shù)(≤20), (1)選擇一種合并石子的方案,使得做N-1次合并,得分的總和最少
(2)選擇一種合并石子的方案,使得做N-1次合并,得分的總和最大例4.石子合并Example用data[i,j]表示合并第i~j顆石子的分值狀態(tài):max[i,j]=max(max[i,k]+max[i+k,j–k]+data[i,k]+data[i+k,j–k])(2<=k<=j)初始條件:max[i,1]=0狀態(tài):min[i,j]=min(min[i,k]+min[i+k,j–k]+data[i,k]+data[i+k,j–k])(0<=k<=j)初始條件:min[i,0]=0時(shí)間復(fù)雜度:O(N^2)Solution在一條馬路上,有一排燈,一個(gè)小朋友要去關(guān)燈,如果燈沒有被關(guān)掉,就會(huì)每秒造成一定的損失。小朋友一開始在某一個(gè)位置,在他左邊和右邊分別有一些燈,給出這些燈和他的距離以及每個(gè)燈每秒會(huì)造成的損失,求一個(gè)方案使得損失最小,輸出最小損失。燈的個(gè)數(shù)<=1000例5.關(guān)燈問題關(guān)掉的燈一定是一個(gè)連續(xù)的區(qū)間如果路過一個(gè)燈但是沒有去關(guān)掉它……設(shè)opt[i][j][0/1]表示區(qū)間[i,j]中的燈都被關(guān)掉之后的最小損失,最后一維表示小朋友的當(dāng)前位置轉(zhuǎn)移:考慮當(dāng)前的關(guān)燈操作時(shí)間復(fù)雜度:O(N^2)Solutionsubtree的左子樹的加分×subtree的右子樹的加分+subtree的根的分?jǐn)?shù)
若某個(gè)子樹為主,規(guī)定其加分為1,葉子的加分就是葉節(jié)點(diǎn)本身的分?jǐn)?shù)。不考慮它的空子樹。
試求一棵符合中序遍歷為(1,2,3,…,n)且加分最高的二叉樹tree。Solution注意到任意一棵子樹的中序遍歷一定是一段連續(xù)的區(qū)間枚舉區(qū)間中的第幾個(gè)元素作為這一段區(qū)間的根記f[i][j]表示中序遍歷為[i,j]這個(gè)區(qū)間的子樹的最大分?jǐn)?shù),g[i]表示第i個(gè)點(diǎn)的分?jǐn)?shù)F[i][j]=max(F[i][k-1]*F[k+1][j]+g[i])初始條件:F[i][j]=0Solution見外部題目描述例8.psolve狀態(tài):F[i][j]表示i~j在一個(gè)月做完的最小所需月份枚舉上一個(gè)做了k~i-1轉(zhuǎn)移方程:F[i][j]=min(F[k][i-1]+1),s1[i][j]+s2[k][i-1]<=P,且F[k][i-1]合法初始條件:F[0][0]=1此題寫起來有好多小細(xì)節(jié),建議練習(xí)代碼Solution動(dòng)態(tài)規(guī)劃問題具有以下基本特征:1、問題具有多階段決策的特征。2、每一階段都有相應(yīng)的“狀態(tài)”與之對(duì)應(yīng),描述狀態(tài)的量稱為“狀態(tài)變量”。3、每一階段都面臨一個(gè)決策,選擇不同的決策將會(huì)導(dǎo)致下一階段不同的狀態(tài)。4、每一階段的最優(yōu)解問題可以遞歸地歸結(jié)為下一階段各個(gè)可能狀態(tài)的最優(yōu)解問題,各子問題與原問題具有完全相同的結(jié)構(gòu)。動(dòng)態(tài)規(guī)劃的基本模型狀態(tài)壓縮是一種非常暴力的動(dòng)態(tài)規(guī)劃,特征也非常明顯,一般適用于數(shù)據(jù)規(guī)模較小的情況。狀態(tài)壓縮復(fù)雜度通常情況下是是指數(shù)級(jí)的,編程復(fù)雜度也相對(duì)較大。所謂狀態(tài)壓縮,就是把一個(gè)比較復(fù)雜的狀態(tài)壓縮為一個(gè)數(shù),通常采用某一種進(jìn)制的表示方法經(jīng)常通過記憶化搜索來實(shí)現(xiàn)Part3.狀態(tài)壓縮動(dòng)態(tài)規(guī)劃放寒假了,小D終于可以回家了。一個(gè)學(xué)期之后他有太多的東西想帶回家。小D的背包可以被看作一個(gè)4行N列的矩陣,每個(gè)物品放入背包的物品恰好需要占據(jù)兩個(gè)相鄰的方格,任意兩個(gè)物品不能占據(jù)相同的方格。為了充分的利用自己的背包,小D希望背包的所有空間都放置了物品,也就是說,背包中恰好放入了2N個(gè)物品?,F(xiàn)在小D想知道,不同的放置方案數(shù)有多少種。例9.多米諾骨牌覆蓋搜索?n很大,超時(shí)嚴(yán)重動(dòng)態(tài)規(guī)劃?如何表示狀態(tài)?注意到每一列最多只有4行,每一個(gè)格子對(duì)下一行的影響只有2種:下一行對(duì)應(yīng)的格子是否可以和當(dāng)前格子一起放進(jìn)一個(gè)物品狀態(tài)壓縮!0/1表示每個(gè)格子的狀態(tài),4位二進(jìn)制數(shù)表示一行的狀態(tài)Solution用F[k][S]來描述一個(gè)狀態(tài),這個(gè)狀態(tài)表示已經(jīng)把矩陣的前k-1列全部放滿,并且第k列的覆蓋情況為S(s為一個(gè)4位二進(jìn)制數(shù)),此時(shí)的擺放方案數(shù)(注意,其實(shí)只有S中1的個(gè)數(shù)為偶數(shù)時(shí)狀態(tài)才有意義,更加深入的探討會(huì)發(fā)現(xiàn)需要使用的狀態(tài)很少)。通過枚舉第k列骨牌的放置方案,不難得到從F[k][u](u=0…15)到F[k+1][v](v=0…15)的轉(zhuǎn)移方程。這個(gè)過程需要另外寫一個(gè)程序去枚舉才能完成。SolutionL盞燈,每盞燈為0/1,表示亮的或暗的有一個(gè)叉子有T個(gè)叉尖,相鄰兩個(gè)叉尖的距離等于相鄰兩盞燈的距離。有些叉尖斷了,用0表示,否則為1叉子對(duì)準(zhǔn)開關(guān),可以改變燈的狀態(tài)已知初始燈的狀態(tài)和叉尖狀態(tài),求叉尖操作的序列使得最后亮著的燈最少L<=50,T<=7例10.xlite同一位置只可能操作一次可以從左到右依次操作F[i][S]表示最后T盞燈燈的狀態(tài)為S時(shí),前i盞燈至少還亮著多少盞S為一個(gè)T位
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(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)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024版汽車銷售合同范本
- 2024陜西智能制造行業(yè)勞動(dòng)合同范本3篇
- 二零二五年度餐飲品牌加盟店合同范本3篇
- 2024版施工工程勞務(wù)分包合同
- 二零二五年高溫高壓管道材料購銷合同2篇
- 專用倉儲(chǔ)物流倉庫建設(shè)施工協(xié)議模板版B版
- 二零二五版國有企業(yè)員工勞動(dòng)合同解除與經(jīng)濟(jì)補(bǔ)償協(xié)議3篇
- 二零二五版?zhèn)€人購房貸款擔(dān)保與房屋權(quán)屬登記服務(wù)合同3篇
- 2024版代生產(chǎn)加工服務(wù)合同范本2篇
- 二零二五年度特色餐飲品牌加盟保密合同范本3篇
- 不同茶葉的沖泡方法
- 光伏發(fā)電并網(wǎng)申辦具體流程
- 基本藥物制度政策培訓(xùn)課件
- 2025年中國華能集團(tuán)限公司校園招聘高頻重點(diǎn)提升(共500題)附帶答案詳解
- 建筑勞務(wù)專業(yè)分包合同范本(2025年)
- GB/T 45002-2024水泥膠砂保水率測定方法
- 廣東省廣州海珠區(qū)2023-2024學(xué)年八年級(jí)上學(xué)期期末數(shù)學(xué)試卷(含答案)
- 飛行原理(第二版) 課件 第10章 高速空氣動(dòng)力學(xué)基礎(chǔ)
- 央國企信創(chuàng)白皮書 -基于信創(chuàng)體系的數(shù)字化轉(zhuǎn)型
- GB/T 36964-2018軟件工程軟件開發(fā)成本度量規(guī)范
- 機(jī)加車間各崗位績效考核方案
評(píng)論
0/150
提交評(píng)論