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

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

動態規劃(一)

2019-11-11 06:15:55
字體:
來源:轉載
供稿:網友

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

基本概念

    動態規劃(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
在线精品高清中文字幕| 亚洲男人的天堂网站| 亚洲国产精品va在看黑人| 欧美一级片在线播放| 国产精品美乳一区二区免费| 亚洲国产成人精品久久久国产成人一区| 久久精品2019中文字幕| 欧美日韩激情小视频| 亚洲天堂视频在线观看| 精品无人区乱码1区2区3区在线| 久久精品国产亚洲7777| 成人精品久久久| 91精品国产综合久久男男| 久久久久久久激情视频| 亚洲国产欧美一区二区三区同亚洲| 日韩免费av一区二区| 国产亚洲精品综合一区91| 精品福利在线看| 欧美精品一区二区三区国产精品| 欧美成人免费va影院高清| 欧美诱惑福利视频| 欧美在线激情视频| 日韩精品中文字幕久久臀| 久久精品国产欧美亚洲人人爽| 日韩欧美在线视频日韩欧美在线视频| 国产精品日韩在线观看| 欧美黑人性猛交| 欧美肥婆姓交大片| 精品日本美女福利在线观看| 一本一本久久a久久精品综合小说| 最近2019中文字幕大全第二页| 亚洲色图18p| 91在线视频精品| 日韩欧中文字幕| 国产精品一区二区三区成人| 伊人伊成久久人综合网小说| 中文字幕在线观看日韩| 亚洲视屏在线播放| 在线观看国产欧美| 欧美第一黄网免费网站| 国产成人精品视频在线观看| 国产91久久婷婷一区二区| 欧美一区二区三区精品电影| 亚洲91精品在线| 久久91超碰青草是什么| 欧美国产日韩一区| 精品国产一区二区三区久久久狼| 精品国产一区久久久| 日韩电影免费观看在线| 欧美日韩亚洲精品内裤| 国产精品欧美激情在线播放| 欧美大荫蒂xxx| 中文字幕精品视频| 国产精品久久久久久av下载红粉| 日韩欧美一区二区在线| 中文字幕亚洲天堂| 日韩电影免费在线观看| 亚洲男人天堂久| 亚洲а∨天堂久久精品喷水| 亚洲精品国产精品乱码不99按摩| 日韩免费在线免费观看| 丝袜美腿精品国产二区| 国产一区二区三区三区在线观看| 日韩在线激情视频| 国产精品福利在线| 日韩中文字在线| 欧美一级免费看| 国产性色av一区二区| 成人免费自拍视频| 中文字幕日韩电影| 在线视频日本亚洲性| 在线观看亚洲区| 91久久久久久| 亚洲日本aⅴ片在线观看香蕉| 久久精品久久精品亚洲人| 亚洲大尺度美女在线| 日韩国产精品视频| 亚洲风情亚aⅴ在线发布| 97精品国产97久久久久久免费| 97在线观看视频| 中文字幕一区二区精品| 欧美日韩国产激情| 国产精品私拍pans大尺度在线| 成人h猎奇视频网站| 日韩极品精品视频免费观看| 欧美在线视频在线播放完整版免费观看| 欧美日韩精品在线| 色偷偷av一区二区三区| 成人福利免费观看| 成人综合网网址| 亚洲黄色在线观看| 在线视频免费一区二区| 日韩中文字幕不卡视频| 日韩av片免费在线观看| 国产日韩在线看| 亚洲国产三级网| 国产成人精品久久二区二区91| 成人免费看黄网站| 欧美大全免费观看电视剧大泉洋| 日韩免费在线播放| 国产精品自在线| 精品国产乱码久久久久久虫虫漫画| 欧美大片在线看| 国产欧美va欧美va香蕉在线| 日本国产精品视频| 亚洲欧美日韩国产中文专区| 日韩av免费看网站| 欧美成人剧情片在线观看| 欧美日韩国产精品| 一区二区三区动漫| 亚洲天堂av综合网| 久久视频在线视频| 欧美性xxxx极品hd欧美风情| 国产成人在线亚洲欧美| 欧美精品久久久久| 91久久精品国产| 久久久伊人日本| 亚洲国产成人在线播放| 国产欧美精品va在线观看| 久久精品国产亚洲精品2020| 一区二区成人精品| 精品久久久国产精品999| 久久成年人免费电影| 亚洲最大av网站| 亚洲第一免费播放区| 九九热精品视频国产| 亚洲欧洲偷拍精品| 久久影视电视剧免费网站| 亚洲第一天堂无码专区| 最近2019年日本中文免费字幕| 一级做a爰片久久毛片美女图片| 亚洲福利在线看| 国产伦精品一区二区三区精品视频| 美女av一区二区三区| 久久久久久久久91| 国产亚洲人成a一在线v站| 这里只有视频精品| 在线播放日韩专区| 国产日韩专区在线| 国产91在线播放| 中文字幕不卡在线视频极品| 亚洲精品短视频| 92福利视频午夜1000合集在线观看| 欧美噜噜久久久xxx| 亚洲精品一区久久久久久| 欧美国产日韩一区二区在线观看| 亚洲精品乱码久久久久久按摩观| 亚洲国产欧美自拍| 一区二区三区 在线观看视| 成人精品一区二区三区| 成人激情在线观看| 亚洲综合在线小说| 亚洲电影在线观看| 欧美视频在线观看免费| 精品视频在线播放色网色视频| 欧洲中文字幕国产精品| 欧美日韩xxxxx| 亚洲日本aⅴ片在线观看香蕉| 亚洲免费成人av电影| 亚洲成人网久久久| www.午夜精品| 亚洲自拍在线观看| 久久视频在线视频| 欧洲永久精品大片ww免费漫画|