算法分析與設計2006第e講

算法分析與設計2006第e講

ID:14395266

大?。?35.50 KB

頁數(shù):10頁

時間:2018-07-28

算法分析與設計2006第e講_第1頁
算法分析與設計2006第e講_第2頁
算法分析與設計2006第e講_第3頁
算法分析與設計2006第e講_第4頁
算法分析與設計2006第e講_第5頁
資源描述:

《算法分析與設計2006第e講》由會員上傳分享,免費在線閱讀,更多相關內容在教育資源-天天文庫。

1、上次內容:(1)圖著色不能多項式時間近似到小于,TSP問題不能多項式時間近似到任意常數(shù)。(2),時間復雜度O(mK+nlogn),K越大求解優(yōu)化程度越高,1+e,T=O()。M是常數(shù)時可以認為是多項式時間近似方案。什么是多項式時間近似方案:定義7.2:若問題p的近似算法A(e)若滿足對任意實例I任意e>0(1)RA(e)[I]<1+e;(2)A(e)的時間復雜度是I輸入長度的多項式函數(shù)。則A(e)稱為求解問題p的多項式時間近似方案。解釋:(1)1+e很容易說明,但后面的多項式需要解釋,時間復雜度一定與e有關。近似性能比1+e,時間復雜度為:O

2、(),O(n),O(n2),PTAS。特殊情況:O()等等,各種情況。一定是e越小,時間復雜度越大。最后一種情況又稱為完全多項式時間近似方案。FPTAS完全多項式時間近似方案:近似度1+e;時間復雜度:P(n,),P(·,·)是多項式函數(shù)。(2)為什么叫多項式近似方案,而不叫多項式近似算法。因為e沒有確定大小,只有程序運行時才能確定。再考慮背包問題:設計真正的多項式時間近似方案。,xi?{0,1},I=1,…,n設元素:a1,a2,…,an

3、p1,p2,…,pn

4、w1,w2,…,wn(1)簡單算法描述先挑k個元素放入背包,然后調用前面7.1節(jié)

5、算法選擇其他元素裝包。兩種規(guī)則,價值重量比大者優(yōu)先;價值大者優(yōu)先,二者擇優(yōu)選一為最終解。這樣裝法顯然不一定多么好,若對任意一種k個元素的組合都先放入背包嘗試,則最后結果一定比直接裝入好。全部嘗試完后選擇最好的,作為最后結果。算法描述:Proceduree-approx(P,W,M,n,K)1Pmax=0;2forallcombinationsIofsize£Kandweight£Mdo//不超過K元素的組合3PI=;4Pmax=max{Pmax,PI+L(I,P,W,M,n)}//L(I,P,W,M,n)是子程序。用于計算剩余容量裝包。5en

6、dfor6end下面這個算法是先試裝k個后再繼續(xù)裝ProcedureL(I,P,W,M,n)//I是已經(jīng)裝入的元素集合(1)S=0;T=M-;IS=?(2)Fori=1tondo(3)Ifi?IandWi£Tthen(4)S=S+Pi;T=T-Wi;IS=IS+{i}(5)Endif(6)EndforReturn(max{S,max{Pi

7、i?I,1£i£n}})//S是由第一種策略裝進包的,后面是第二種策略裝進包的,比較取優(yōu)。End例子:n=8,M=110。P1P2P3P4P5P6P7P811213133435355651112123334

8、34555上面已經(jīng)按照價值重量比排好序了。(1)K=0時,直接從頭開始裝入:x1,x2,x3,x4,x5,x6,x7,x8=11111000,前5個裝入背包Pmax=11+21+31+33+43=139W=1+11+21+23+33=89(2)K=1,時,先裝入1個,再裝入其他,得到1,2,3,4,7最好x1,x2,x3,x4,x5,x6,x7,x8=11110010Pmax=11+21+31+33+45=151W=1+11+21+23+45=101(3)k=2,先裝入2個,再裝入其他,得到1,2,3,5,6最好x1,x2,x3,x4,x5,

9、x6,x7,x8=1,1,1,0,1,1,0,0Pmax=11+21+31+43+53=159W=109=1+11+21+33+43這是最優(yōu)解。定理7.15設背包問題最優(yōu)解為P*,Pmax是前述先裝算法e-approx得到的解,則對任意背包問題實例均成立。證明://為什么會很好呢?因為有可能將最優(yōu)解前K個價值最大的先裝入。(1)給定實例,設R是該實例最優(yōu)解的裝入背包元素下標集合,若

10、R

11、£K,則能夠求到最優(yōu)解,以下假設

12、R

13、>K。(2)將R中的元素的價值重量寫成有序對,按照以下規(guī)則重新排序:(),(),…,()

14、

15、(),…,()。(*),…,

16、是R中元素前k個最大價值,3…33,1£j£

17、R

18、-k。(*)從i=k+1開始按照價值重量比排序3…3。(3)考慮先將R中前K個元素裝入背包的情況,有一種這樣情況。PI=設S是調用L(I,P,W,M,n)增加的收益。會不會將R中元素全部裝入包?則:P*

19、ax3PI+L,這僅是一種情況得到裝包收益為PI+S,算法是所有情況都試遍得到的解,結果不會比這次差。,m>k,S3,Pmax3(K+1)所以前面的不等式成立。沒有

當前文檔最多預覽五頁,下載文檔查看全文

此文檔下載收益歸作者所有

當前文檔最多預覽五頁,下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學公式或PPT動畫的文件,查看預覽時可能會顯示錯亂或異常,文件下載后無此問題,請放心下載。
2. 本文檔由用戶上傳,版權歸屬用戶,天天文庫負責整理代發(fā)布。如果您對本文檔版權有爭議請及時聯(lián)系客服。
3. 下載前請仔細閱讀文檔內容,確認文檔內容符合您的需求后進行下載,若出現(xiàn)內容與標題不符可向本站投訴處理。
4. 下載文檔時可能由于網(wǎng)絡波動等原因無法下載或下載錯誤,付費完成后未能成功下載的用戶請聯(lián)系客服處理。