亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

動態規劃(一)

2019-11-11 04:17:17
字體:
來源:轉載
供稿:網友

    動態規劃通常用來解決最優化問題,通過做出一組選擇來達到最優解。在做出每個選擇的同時,通常會生成與原問題形式相同的子問題。當多于一個選擇子集都生成相同的子問題時,動態規劃技術通常就會很有效,其關鍵技術就是對每個這樣的子問題都保存其解,當其重復出現時即可避免重復求解。

基本概念

    動態規劃(dynamic PRogramming)與分治方法相似,都是通過組合子問題的解來求解原問題。分治方法將問題劃分為互不相交的子問題,遞歸的求解子問題,再將他們的解組合起來,求出原問題的解。與之相反,動態規劃應用于子問題重疊的情況,不同的子問題具有公共的子子問題。在這種情況下,分治算法會做許多不必要的工作,它會反復地求解那些公共子問題,而動態規劃算法對每個子子問題只求解一次,將其解保存在一個表格中,從而無需每次求解一個子子問題時都重新計算,避免了這種 不必要的計算工作。     動態規劃常用來求解最優化問題(optimization problem),這類問題可以有很多可行解,每個解都有一個值,尋找最優值(最大值或最小值)的解,稱這樣的解為問題的一個最優解(an optimal solution),而不是最優解(the optimal solution),因為有可能有多個解都達到最優值。     通常用4個步驟來設計一個動態規劃算法: 1. 刻畫一個最優解的結構特征; 2. 遞歸的定義最優解的值; 3. 計算最優解的值,通常采用自底向上的方法; 4. 利用計算出的信息構造一個最優解 。

鋼條切割

問題描述

    鋼條切割問題:給定一段長度為n英寸的鋼條和一個價格表pi(i=1,2,???,n),求切割鋼條方案,使得銷售收益rn最大,鋼條可以0切割。

最優解的結構特征

    長度為n英寸的鋼條共有2^(n-1)中不同的切割方案,因為在距離鋼條左端i(i=1,2,???,10)英寸出,我們總是可以選擇切割或不切割。一個最優解就是將鋼條切割為k段(1<=k<=n),那么最優切割方案為 n=i1+i2+???+ik 將鋼條切割為長度分別為i1,i2,???,ik的小段,得到最大收益 rn=pi1+pi2+???+pik 更一般的,對于rn,可以用更短的鋼條的最優切割收益來描述它 rn=max(pn,r1+r(n-1),r2+r(n-2),???,r(n-1)+r1)

遞歸定義最優解

    根據上面得到的式子,采用遞歸的方法,偽代碼如下:

CUT_ROD(p, n)if n == 0 return 0q = -1for i = 1 to n q = max (q, p[i] + CUT_ROD(p, n - i)return q

    從上面的遞歸中可以看出,每個n值,都會反復的計算前面已經計算過的值,當n比較大時,遞歸調用的工作量會爆炸性的增長,所以應該采用動態規劃的方法求解。

自底向上計算最優解的值

    動態規劃有兩種等價的實現方法。     第一種方法稱為帶備忘的自頂向下法(top-down with memorization)。此方法仍按照自然的遞歸形式編寫過程,但過程會保存每個子問題的解(通常保存在一個數組或哈希表中),我們稱這個遞歸過程是帶備忘的(memoized)。     第二種方法稱為自底向上法(bottom-up method)。這種方法一般需要恰當定義子問題“規?!钡母拍睿沟萌魏巫詥柕那蠼舛贾灰蕾囉凇案〉摹弊訂栴}的求解,因而可以將子問題按規模排序,按由小至大的順序進行求解。     兩種方法得到的算法具有相同的漸進運行時間,僅有的差異是在某些特殊情況下,自頂向下方法并未真正遞歸地考察所有可能的子問題,由于沒有頻繁的遞歸函數調用的開銷,自底向上方法的時間復雜性函數通常具有更小的系數。     這里采用第二種方法的偽代碼如下:

BOTTOM_UP_CUT_ROD(p, n)let r[n] be a new arrayr[0] = 0for j = 1 to n q = -1 for i = 1 to j q = max(q, p[i] + r[j – i]) r[j] = qreturn r[n]

構造最優解

    上面的偽代碼已經計算出最優解的值,但缺少最優解的方案,可以稍加修改,添加數組s記錄n英寸鋼條最優切割方案的第一段切割長度:

EXTENDED-BOTTOM-UP-CUT-ROD(p, n)let r[n] and s[n] be new arraysr[0] = 0for j = 1 to n q = -1 for i = 1 to j if q < p[i] + r[j – i] q = p[i] + r[j – i] s[j] = i r[j] = qreturn r and s

    通過下面的偽代碼來輸出完整的最優切割方案:

PRINT_CUT_ROD_SOLUTION(p, n)(r, s) = EXTENDED-BOTTOM-UP-CUT-ROD(p, n)while n > 0 print s[n] n = n – s[n]

矩陣鏈乘法

問題描述

    給定n個矩陣的鏈[A1,A2,???,An],矩陣Ai的規模為p(i-1)*pi(1<=i<=n),求完全括號化方案,使得計算乘積A1A2???An所需標量乘法次數最少。

最優解的結構特征

    和鋼條切割問題相似,A1A2???An其實就可以寫成A1???AkA(k+1)???An,其中A1???Ak和A(k+1)???An就成為了兩條子鏈,同理,子鏈亦可往下分解,原來的問題就變成了求解這些子鏈的的問題。

遞歸求解方案

    令m[i, j]表示計算矩陣鏈所需標量乘法次數的最小值,原問題的最優解的值為m[1, n],很容易,我們得到 m[i, j] = m[i, k] + m[k+1, j] + p(i-1)pkpj,當i=j時,m[i , j]=0.

計算最優解的值

    根據上面的遞歸公式,假設矩陣Ai的規模為p(i-1)*pi,它的出入序列是p=[p0,p1,???,pn],過程中用輔助表m保存代價m[i, j],用輔助表s記錄最優值m[i, j]對應的分割點k。偽代碼如下:

MATRIX_CHAIN_ORDER(p)n = p.length – 1let m[n+1][n+1] and s[n][n+1] be new tablesfor i = 1 to n m[i, i] = 0 for i =2 to n for i = 1 to n-l+1 j = i + l – 1 m[i , j] = -1 for k = i to j-1 q = m[i, k] + m[k+1, j] + p(i-1)pkpj if m[i, j] < 0 or q < m[i, j] m[i, j] = q s[i, j] = kreturn m and s

構造最優解

    利用遞歸求解的思路遞歸的輸出最優括號方案,偽代碼如下:

PRINT_OPTIMAL_PARENS(s, i, j)if i == j return “A”ielse print “(“ PRINT_OPTIMAL_PARENS(s, i, s[i, j]) PRINT_OPTIMAL_PARENS(s, s[i, j] + 1, j) print “)”
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日本成人在线视频网址| 97国产精品免费视频| 久久久国产精品视频| 91精品国产色综合久久不卡98口| 欧美韩日一区二区| 色综合久久天天综线观看| 欧美劲爆第一页| 少妇av一区二区三区| 国产亚洲欧美一区| 欧美成人午夜剧场免费观看| 久久精品中文字幕| 日韩在线观看网站| 亚洲春色另类小说| 中文字幕免费精品一区| 欧美视频在线观看免费网址| 中文字幕亚洲无线码在线一区| 国产精品久久久久免费a∨大胸| 亚洲美女性生活视频| 亚洲欧美综合图区| 久久精品最新地址| 日韩hd视频在线观看| 国产一区二区三区高清在线观看| 欧美丰满少妇xxxxx| 97视频在线观看免费| 亚洲高清免费观看高清完整版| 九九热视频这里只有精品| 国产免费一区二区三区在线观看| 在线看日韩av| 国产成人精品久久亚洲高清不卡| 国产69精品99久久久久久宅男| 人体精品一二三区| 日韩精品在线免费播放| 国产精品久久久久久网站| 欧美黑人视频一区| 97超碰蝌蚪网人人做人人爽| 狠狠躁夜夜躁人人爽天天天天97| 国产精品久久久久久久久久尿| 国产丝袜高跟一区| 91日本视频在线| 成人www视频在线观看| 日韩福利视频在线观看| 精品国产自在精品国产浪潮| 91精品91久久久久久| 在线视频中文亚洲| 亚洲国内高清视频| 国产亚洲欧美aaaa| 日韩专区中文字幕| 久久中国妇女中文字幕| 538国产精品一区二区免费视频| 久久婷婷国产麻豆91天堂| 欧美国产视频日韩| 欧美日韩国产va另类| 91av在线看| 国产欧美一区二区三区在线看| 亚洲第一区第一页| 国产精品视频资源| 亚洲伊人一本大道中文字幕| 亚洲成人a级网| 国产99久久精品一区二区| 狠狠爱在线视频一区| 国产免费一区二区三区在线观看| 久久精品色欧美aⅴ一区二区| 亚洲少妇激情视频| 久久青草精品视频免费观看| 精品国产91久久久久久老师| 欧美中文在线观看| 欧美国产精品人人做人人爱| 91精品国产高清自在线| 亚洲欧美日本另类| 精品久久久久久久大神国产| 国产成人精品久久亚洲高清不卡| 亚洲v日韩v综合v精品v| 亚洲欧洲激情在线| 久久久久久久影视| 岛国av午夜精品| 国产成人jvid在线播放| 国产精品丝袜久久久久久不卡| 久久免费视频网| 国产精品久久久久久久久久新婚| 热久久这里只有| 伊人久久大香线蕉av一区二区| 国产女精品视频网站免费| 国产xxx69麻豆国语对白| 国产精品久久久久免费a∨| 亚洲精品一区av在线播放| 亚洲视频在线免费观看| 亚洲成年网站在线观看| 亚洲加勒比久久88色综合| 欧美激情视频一区二区| 91夜夜揉人人捏人人添红杏| 欧美午夜宅男影院在线观看| 国产日韩欧美91| 亚洲欧美精品suv| 国产综合在线观看视频| 国产一级揄自揄精品视频| 日韩小视频在线观看| 欧美极品欧美精品欧美视频| 亚洲影视九九影院在线观看| 国产有码一区二区| 国产91免费观看| 7777精品久久久久久| 色妞色视频一区二区三区四区| 久久久久国产精品www| 亚洲影院色无极综合| 亚洲在线免费看| 中日韩美女免费视频网站在线观看| 欧美日韩在线免费观看| 欧美日韩亚洲一区二区| 久久艳片www.17c.com| 日韩欧美在线观看| 欧美极品少妇全裸体| 久久亚洲精品网站| 亚洲国产精品va在线观看黑人| 成人xvideos免费视频| 中文字幕九色91在线| 国产精品久久9| 国产69精品久久久久9999| 成人乱人伦精品视频在线观看| 日韩av成人在线观看| 国产午夜精品理论片a级探花| 九九精品在线观看| 国产97人人超碰caoprom| 在线观看视频亚洲| zzijzzij亚洲日本成熟少妇| 疯狂欧美牲乱大交777| 在线精品国产欧美| 97碰碰碰免费色视频| 亚洲高清福利视频| 国产免费一区视频观看免费| 91免费的视频在线播放| 热99精品只有里视频精品| 欧美日韩国产成人在线观看| 欧美体内谢she精2性欧美| 色av中文字幕一区| 国产成人高清激情视频在线观看| 国产成人亚洲综合91精品| 欧美亚洲成人精品| 国产成人综合亚洲| 91理论片午午论夜理片久久| 亚洲一区二区三区四区视频| 日韩精品在线观看视频| 日韩高清av一区二区三区| 亚洲香蕉伊综合在人在线视看| 久久亚洲春色中文字幕| 国产福利视频一区二区| www国产精品com| 影音先锋日韩有码| 久久精品国产久精国产一老狼| 欧美成人午夜剧场免费观看| 国产亚洲a∨片在线观看| 大胆欧美人体视频| 亚洲免费高清视频| 亚洲国产成人精品女人久久久| 456国产精品| 久久久极品av| 38少妇精品导航| 亚洲精品国产综合区久久久久久久| 亚洲欧美另类国产| 亚洲成色777777女色窝| 亚洲视频一区二区| 亚洲黄色有码视频| 中文字幕在线成人| 国产精品久久久久久亚洲调教| 日韩中文在线中文网三级|