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

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

動態規劃(一)

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

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

基本概念

    動態規劃(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
久久影视三级福利片| 国产精品91久久久| 亚洲成人在线视频播放| 超碰91人人草人人干| 91精品国产高清久久久久久久久| 2024亚洲男人天堂| 国产成人精品av| 91免费精品国偷自产在线| 亚洲一区二区三区乱码aⅴ蜜桃女| 青青在线视频一区二区三区| 色哟哟亚洲精品一区二区| 26uuu另类亚洲欧美日本一| 亚洲免费影视第一页| 一区二区三区回区在观看免费视频| 91精品久久久久久久久中文字幕| 国产欧美日韩免费看aⅴ视频| 色樱桃影院亚洲精品影院| 日韩亚洲第一页| 国产精品女主播| 欧美性69xxxx肥| 日韩国产高清视频在线| 国产美女直播视频一区| 亚洲一区亚洲二区亚洲三区| 色噜噜狠狠色综合网图区| 国产在线观看精品一区二区三区| 91地址最新发布| 欧美黑人狂野猛交老妇| 亚洲最大av网| 日韩欧美亚洲一二三区| 久久久精品视频成人| 久久久在线观看| 亚洲综合大片69999| 国产精品第一第二| 亚洲欧洲在线看| 亚洲精品乱码久久久久久金桔影视| 欧美精品一区二区免费| 国内久久久精品| 欧美日韩国产在线看| 爽爽爽爽爽爽爽成人免费观看| 亚洲最新中文字幕| 国产精品久久久久久久久影视| 中文字幕无线精品亚洲乱码一区| 亚洲在线一区二区| 欧美日本在线视频中文字字幕| 国内外成人免费激情在线视频| 亚洲精品小视频在线观看| 国产精品高精视频免费| 免费91麻豆精品国产自产在线观看| 欧美日韩国产中文精品字幕自在自线| 久久免费视频在线观看| 国产美女精品视频| 日韩电影免费观看中文字幕| 国产精品久久久久久久久久三级| 欧美又大又硬又粗bbbbb| 一级做a爰片久久毛片美女图片| 国产成人91久久精品| 97久久久免费福利网址| 国产欧亚日韩视频| 亚洲sss综合天堂久久| 国产精品自拍偷拍视频| 亚洲成人网在线观看| 亚洲精品在线看| 欧美高清激情视频| 久久久精品国产一区二区| 成人午夜黄色影院| 欧美视频不卡中文| 亚洲国产精品悠悠久久琪琪| 欧美极品少妇xxxxⅹ免费视频| 成人欧美一区二区三区黑人孕妇| 欧美性xxxxxxxxx| 久久综合久中文字幕青草| 国产精品九九久久久久久久| xxxxx成人.com| 少妇激情综合网| 日本精品性网站在线观看| 日产日韩在线亚洲欧美| 欧美高清视频在线| 日韩中文第一页| 秋霞成人午夜鲁丝一区二区三区| 久久久久久久影视| 欧美日韩国产麻豆| 国产欧美精品一区二区| 中文字幕亚洲第一| 性欧美长视频免费观看不卡| 亚洲片在线资源| 亚洲影院色在线观看免费| 亚洲成人网久久久| 91香蕉亚洲精品| 国产精品国产三级国产专播精品人| 91精品国产91久久久久| 在线看日韩av| 国产精品国产三级国产aⅴ9色| 中文字幕精品视频| 九九视频直播综合网| 国产精品三级久久久久久电影| 国外成人免费在线播放| 久久久精品影院| 日韩美女视频中文字幕| 91免费视频网站| 日韩av手机在线| 久久精品夜夜夜夜夜久久| 国产激情综合五月久久| 国产日韩av高清| 亚洲自拍小视频免费观看| 亚洲最大成人网色| 麻豆乱码国产一区二区三区| 国产精品日韩欧美| 亚洲欧美在线免费| 国产欧美久久一区二区| 日韩av在线导航| 最好看的2019年中文视频| 亚洲www永久成人夜色| 国产日韩欧美在线观看| 欧美在线视频一二三| 国产va免费精品高清在线观看| 亚洲永久免费观看| 国语自产偷拍精品视频偷| 久久久噜噜噜久久中文字免| 亚洲国产精品一区二区久| 国产区亚洲区欧美区| 欧美精品在线视频观看| 91亚洲精品久久久久久久久久久久| 久久99国产综合精品女同| 久久不射电影网| 26uuu另类亚洲欧美日本老年| 国产成人自拍视频在线观看| 亚洲男人av在线| 欧美精品久久久久久久久| 国产精品成人一区二区| 亚洲欧美一区二区三区四区| 日韩在线中文字| 久久精视频免费在线久久完整在线看| 国产99久久精品一区二区| 欧美激情视频网站| 一区二区三区 在线观看视| 91精品国产综合久久久久久久久| 色多多国产成人永久免费网站| 亚洲综合中文字幕在线| 国产精品久久久亚洲| 亚洲人成网7777777国产| 夜夜躁日日躁狠狠久久88av| 欧美精品免费在线观看| 国产噜噜噜噜噜久久久久久久久| 午夜美女久久久久爽久久| 色琪琪综合男人的天堂aⅴ视频| 国产一区二区三区免费视频| 欧美成人精品在线观看| 日韩av在线网页| 奇米4444一区二区三区| 欧美极品欧美精品欧美视频| 日韩电影中文字幕| 久久99精品久久久久久琪琪| 97国产精品久久| 91精品国产91久久| 国产日韩欧美中文| 一区二区三区黄色| 亚洲aa中文字幕| 国产一区私人高清影院| 在线午夜精品自拍| 国产日本欧美一区二区三区在线| 欧美综合国产精品久久丁香| 亚洲欧美一区二区三区情侣bbw| 亚洲风情亚aⅴ在线发布| 欧美日本国产在线|