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

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

動態規劃(一)

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

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

基本概念

    動態規劃(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
在线观看亚洲视频| 成人黄色影片在线| 亚洲日本成人女熟在线观看| 欧美肥老妇视频| 国产在线观看精品| 国产成人鲁鲁免费视频a| 日韩中文字幕在线视频| 欧美性极品xxxx做受| 久久亚洲一区二区三区四区五区高| 国产精品视频久久久| 91精品国产777在线观看| 色与欲影视天天看综合网| 不卡av在线网站| 亚洲精品资源美女情侣酒店| 欧美插天视频在线播放| 欧美一区二区色| 26uuu另类亚洲欧美日本一| 亚洲人成电影在线播放| 亚洲天堂av在线免费观看| 日韩精品一区二区视频| 日韩中文字幕久久| 亚洲最大福利网| 日韩av电影在线播放| 黄网站色欧美视频| 一区二区三区久久精品| 国产精品国模在线| 日韩精品在线视频观看| 色小说视频一区| 美女999久久久精品视频| 日韩av成人在线| 国产亚洲一区二区精品| 欧美大学生性色视频| 中文字幕国产亚洲2019| 7777kkkk成人观看| 欧美激情在线有限公司| 久久久国产成人精品| 亚洲欧美日韩一区二区三区在线| 亚洲精品一区二区网址| 国产精品手机播放| 成人精品一区二区三区电影免费| 欧美极品少妇全裸体| 中文字幕国内精品| 91在线无精精品一区二区| 亚洲人高潮女人毛茸茸| 另类视频在线观看| 国产亚洲精品美女久久久| 国产精品爽爽爽| 91高清在线免费观看| 国产成人综合久久| 亚洲国产精品电影在线观看| 成人av色在线观看| 国产小视频91| 亚洲一区二区三区成人在线视频精品| 日韩av在线免费看| 欧美在线影院在线视频| 欧美日韩国产一区中文午夜| 日韩在线视频国产| 国产精品对白刺激| 欧洲精品毛片网站| 亚洲精品一区av在线播放| 国产精品十八以下禁看| 91视频九色网站| 亚洲综合色激情五月| 欧美性资源免费| 国产精品一区二区三区毛片淫片| 91免费国产视频| 国产精品va在线播放| 成人有码在线视频| 欧美激情视频在线观看| 91精品国产99| 国产精品精品久久久| 97精品国产97久久久久久免费| 中文字幕亚洲综合久久| 日韩视频中文字幕| 久久久久久久一区二区| 亚洲美女福利视频网站| 精品国产精品三级精品av网址| 久久在线观看视频| 久久久精品在线| 97在线视频一区| 国产日韩专区在线| 18久久久久久| 欧美老女人性生活| 国产亚洲精品成人av久久ww| 国产成人精品网站| 国产一区二区三区中文| 中文字幕欧美日韩va免费视频| 精品久久久久久久久国产字幕| 在线精品国产成人综合| 在线日韩av观看| 国产不卡一区二区在线播放| 亚洲aaaaaa| 久久国内精品一国内精品| 欧美黑人又粗大| 久久久免费高清电视剧观看| 亚洲精品综合久久中文字幕| 亚洲丝袜av一区| 欧美高清视频在线播放| 久久久久国色av免费观看性色| 中文字幕欧美视频在线| 欧美日韩激情小视频| 精品国产欧美成人夜夜嗨| 国产精品久久久久久久一区探花| 亚洲精品美女久久久| 国产精品高潮呻吟久久av野狼| 欧美成人手机在线| 亚洲wwwav| 高清视频欧美一级| 精品中文字幕乱| 欧美性20hd另类| 久久网福利资源网站| 91精品国产91久久久久久吃药| 亚洲春色另类小说| 精品高清美女精品国产区| 日韩欧美亚洲国产一区| 7777kkkk成人观看| 日韩麻豆第一页| 中文字幕亚洲二区| 国产精品视频1区| 国产成人精品最新| 精品视频中文字幕| 日韩在线观看成人| 2018国产精品视频| 成人中文字幕+乱码+中文字幕| 亚洲第一视频在线观看| 国产精品视频99| 午夜精品久久久99热福利| 韩国美女主播一区| 国产亚洲欧美另类中文| www.美女亚洲精品| 欧美日韩美女在线观看| 亚洲欧美国产va在线影院| 欧美日韩国产一中文字不卡| 美女999久久久精品视频| 国产在线视频一区| 91精品国产色综合久久不卡98| 国产亚洲精品va在线观看| 中文字幕久热精品视频在线| 色综合久久中文字幕综合网小说| 亚洲欧美中文日韩在线v日本| 欧美日产国产成人免费图片| 亚洲人成伊人成综合网久久久| 精品露脸国产偷人在视频| 日韩中文视频免费在线观看| 亚洲午夜精品久久久久久性色| 68精品久久久久久欧美| 中文字幕在线精品| 欧美电影《睫毛膏》| 久久亚洲精品一区二区| 日本欧美中文字幕| 国产精品亚洲激情| 美女撒尿一区二区三区| 中文字幕9999| 久久综合88中文色鬼| 欧美电影在线观看高清| 欧美电影在线播放| 久久国产精品影片| 日韩免费不卡av| 亚洲国产精品va在线看黑人动漫| 国产亚洲精品美女久久久久| 欧美激情视频免费观看| 影音先锋日韩有码| 欧美日韩亚洲天堂| 亚洲成人黄色网|