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

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

動態規劃(一)

2019-11-11 05:22:46
字體:
來源:轉載
供稿:網友

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

基本概念

    動態規劃(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
国产婷婷成人久久av免费高清| 国产在线观看精品一区二区三区| 亚洲精品国产精品自产a区红杏吧| 久久精品中文字幕免费mv| 欧美最近摘花xxxx摘花| 日韩va亚洲va欧洲va国产| 欧美电影免费在线观看| 亚洲欧美中文日韩在线v日本| 另类天堂视频在线观看| 国产性猛交xxxx免费看久久| 欧美成人第一页| 91精品在线观看视频| 国产午夜精品免费一区二区三区| 久久在精品线影院精品国产| 欧日韩不卡在线视频| 日韩欧美一区二区在线| 亚洲精品视频在线观看视频| 久久香蕉国产线看观看网| 欧美精品一本久久男人的天堂| 亚洲人成伊人成综合网久久久| 91免费的视频在线播放| 69视频在线播放| 久久香蕉国产线看观看av| 8090成年在线看片午夜| 国产丝袜一区视频在线观看| 欧美激情视频给我| 57pao成人永久免费视频| 日韩极品精品视频免费观看| 国产一区二区三区直播精品电影| 精品久久久视频| 亚洲电影免费观看高清完整版在线| 日韩在线观看免费高清完整版| 最近2019中文免费高清视频观看www99| 国产精品中文字幕久久久| 国产成人91久久精品| 国产91免费看片| 亚洲天堂av女优| 久久人人爽人人爽人人片av高清| 黄色成人av在线| 日韩欧美国产一区二区| 性欧美办公室18xxxxhd| 亚洲第一网中文字幕| 一区二区三区高清国产| 2019国产精品自在线拍国产不卡| 日韩在线中文视频| 成人在线视频福利| 欧美自拍视频在线| 中日韩美女免费视频网址在线观看| 日韩精品在线免费播放| 欧美日韩国产va另类| 国产精品久久久久久影视| 欧美激情精品久久久久久免费印度| 日韩中文在线中文网三级| 中文字幕精品国产| 日本久久久久久久| 亚洲最大成人在线| 亚洲第一偷拍网| 日韩精品一二三四区| 欧美精品一区在线播放| 亚洲国语精品自产拍在线观看| 久久综合久久八八| 国模吧一区二区三区| 在线电影中文日韩| 亚洲女人天堂成人av在线| 久久久噜久噜久久综合| 亚洲一区二区三区视频| 91亚洲一区精品| 国产午夜精品全部视频在线播放| 91精品久久久久| 国产精品欧美一区二区| 国产网站欧美日韩免费精品在线观看| 日韩美女av在线| 亚洲国产精品成人一区二区| 欧美伊久线香蕉线新在线| 欧美电影免费观看高清完整| 97福利一区二区| 欧美人交a欧美精品| 久久噜噜噜精品国产亚洲综合| 日本国产欧美一区二区三区| 性欧美在线看片a免费观看| 国产精品亚洲视频在线观看| 国产精品视频一区二区高潮| 国产欧美一区二区三区在线| 亚洲欧美精品中文字幕在线| 操91在线视频| 国产精品久久一区主播| 伊人伊成久久人综合网站| 国产丝袜一区二区三区| 欧美一性一乱一交一视频| 亚洲美女免费精品视频在线观看| 日韩美女av在线免费观看| 国产亚洲视频在线观看| 国语对白做受69| 2019精品视频| 色多多国产成人永久免费网站| 日韩av在线影院| 国产99久久精品一区二区 夜夜躁日日躁| 精品久久久久久久久久| 日韩中文字幕不卡视频| 欧美在线免费看| 97超视频免费观看| 欧美精品做受xxx性少妇| 国产精品r级在线| 国产精品揄拍一区二区| 久久精品国产亚洲精品| 亚洲跨种族黑人xxx| 久久av资源网站| 伊人久久久久久久久久久久久| 国产一区二区av| 亚洲黄色www网站| 久久精品国产亚洲7777| 8050国产精品久久久久久| 国产一区av在线| 日本一本a高清免费不卡| 亚洲天堂开心观看| 欧美日韩国产综合视频在线观看中文| 亚洲第一视频在线观看| 国产日韩精品综合网站| 欧美色道久久88综合亚洲精品| 日本中文字幕不卡免费| 欧美高清在线观看| 乱亲女秽乱长久久久| 欧美—级高清免费播放| 国产欧美日韩精品专区| 4444欧美成人kkkk| 欧美国产日韩在线| 欧美日韩亚洲一区二| 久久精品国产视频| 精品国产一区二区三区在线观看| 久久成人精品视频| 欧美激情aaaa| 久久久久北条麻妃免费看| 国产精品看片资源| 国产精品久久久久久网站| 色综合久久88色综合天天看泰| 国产99久久精品一区二区| 欧美午夜丰满在线18影院| 国产精品高潮呻吟视频| 日韩精品免费看| 欧美日韩在线影院| 亚洲综合日韩中文字幕v在线| 国产午夜精品美女视频明星a级| 亚洲成人av中文字幕| 久久这里只有精品99| 8050国产精品久久久久久| 国产高清视频一区三区| 青青久久av北条麻妃海外网| 国产成人精品久久亚洲高清不卡| 国产精品视频一区二区三区四| 亚洲性猛交xxxxwww| 日韩在线观看免费av| www.欧美精品一二三区| 国产精品久久久久久久久久久不卡| 精品久久久久国产| 欧美大成色www永久网站婷| 日韩a**站在线观看| 亚洲第一精品电影| 亚洲色图50p| 国产亚洲福利一区| 中文字幕亚洲综合久久筱田步美| 成人观看高清在线观看免费| 国产一区二区三区在线| 中文字幕一区二区三区电影| 国产日韩欧美夫妻视频在线观看|