版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、第十章 On-line Algorithms,10.1 Introduction to On-line Algorithms,前九章介紹的算法設計的條件在算法執(zhí)行之前整個輸入數(shù)據(jù)的細節(jié)都很清楚問題是在完全了解輸入數(shù)據(jù)信息條件下解決的實際應用存在不滿足上述條件的情況磁盤調度問題操作系統(tǒng)的頁面調度問題 Data streams,On-line算法在算法設計階段或執(zhí)行之前無完全信息可用,輸入數(shù)據(jù)往往是實時到達的.算法時
2、而正確時而錯誤.實時算法難以給出正確解, 一般是近似算法.實時最小生成樹問題難以給出優(yōu)化解, “最小”需要放棄或改為“小”.On-line算法可能如下工作:當每次一個數(shù)據(jù)到達時, 將其連接到最近的鄰居節(jié)點.下邊是一個六個實時到達節(jié)點的例子.,,,,,1,3,5,,2,6,4,算法工作過程,優(yōu)化解,On-line算法的性能令Con表示On-line算法解的代價令Coff表示Off-line算法解的代價若Con?f(n)C
3、off+c, c是常數(shù), 則稱On-line算法的近似比為 f(n). 這個算法稱為f(n)-competitive,10.2 On-line Euclidean Spanning Tree Problem,問題的定義實時算法設計算法性能分析,問題的定義,輸入: S={v1, v2, …, vn}是平面上的n個點的集合 這n個點并非一次給定, 是逐個出現(xiàn)的 輸出 一個”最小”生成樹,,求解最小生成樹問題的On-li
4、ne算法只能是近似算法,Greedy-On-line-ST(S)1. n=|S|;2. T=0;3. While n?0 Do4. Input(v);5. 把v與V(T)之間最短邊加入T; /*V(T)是T節(jié)點集合 */6. Endwhile,On-Line算法,算法的時間復雜性3-6步需要的比較次數(shù)=1+2+…+(n-1)T(n)=O(n2)解的精確度Greedy-On-line-ST
5、算法的近似比是O(logn)設Tonl是算法產(chǎn)生的生成樹, l是優(yōu)化生成樹的代價或長度, 下邊我們來證明這個結論,算法的性能分析,,,,,引理1. Tonl中第k最長邊的長度最多為2l/k, 1?k?n-1. 證. 令Sk={v | v加入Tonl后, Tonl中出現(xiàn)長度大于2l/k的邊}. 如果|Sk|<k, 則Tonl中至多k-1條邊的長度大于2l
6、/k, 即Tonl中第k最長邊的長度最多為2l/k. 往證|Sk|<k. 由算法的Greedy方法可知, Sk中每個點對之間的距離必大于2l/k. 若不然, 設u和v之間距離小于2l/k, 則加入u(或v)以后, 再加入v(或u)時, 不會產(chǎn)生大于2l/k的邊.,,,,于是, Sk上TSP的優(yōu)化解的長度大于 |Sk|2l/k . 由于任意點集上的TSP優(yōu)化解的長度是其最小生成樹
7、長度的2倍, Sk的最小生成樹的長度大于|Sk|l/k . 因為Sk上最小生成樹長度l’不小于S上最小生成樹長度, 我們有, |Sk|l/k < l’ ? l , 即|Sk|l/k < l, 或 |Sk| < k . 于是, Tonl中第k最長邊的長度最多為2l/k. 定理1. Greedy-On-line-ST算法的近似比是O(logn). 證. 由
8、引理1, Tonl的長度L ? ?1?k?n-12l/k =2l ?1?k?n-11/k =2l?H(n-1)=O(logn). 于是, 算法的近似比為L/l?O(logn).
9、,10.3 On-line Algorithm for Convex hull problems,問題的定義 On-line算法的基本思想 On-line算法算法的性能分析,,問題定義,輸入平面上的n個點的集合Q n個點逐個到達, 并非同時出現(xiàn)輸出CH(Q): Q的convex hull Q的convex hull是一個凸多邊形P, Q的點或者在P上或者在P內,凸多邊形P是具有如下性質多邊形
10、:連接P內任意兩點的邊都在P內,基本思想當k個節(jié)點已經(jīng)到達后, 我們得到一個部分CH,On-line算法的思想,當?shù)趉+1個節(jié)點v到達時如果v落在CH內部, 不需做任何事如果v落在CH外部, 需要調整CH的邊界關鍵是: 記住和調整部分CH邊界,,,平行線近似法 用一組并行線記錄、調整、近似CH,,,,,,,,,,,,,,,,,,,,需要平行移動這條線, 不改變其斜率,,,,,,,近似解,,,平行線的一般形式取m對平行線
11、, 其斜率分別為: 0, tan(?/m), tan(2?/m), …, tan((m-1)?/m).這m對平行線必須滿足:每個輸入節(jié)點必須在所有平行線對內;每對平行線必須盡可能的靠近,輸入節(jié)點序列 p1, p2, …滿足前面條件的m對平行線輸出 近似convex hull序列 a1, a2, … ai是覆蓋p1, p2, …, pi的近似convex hull,On-line算法,算法A初始化: 構造
12、m對平行線, 斜率為0, tan(?/m), …, tan((m-1)?/m); 搜索平行線相交在第一個點p1.第一步: 對于任意一個新到達點pi, 如果pi落在所有平行線對 之間, 不執(zhí)行任何操作; 否則, 平移最接近pi的線到pi, 不改變其斜率, 使pi成為該線的標記.第二步: 沿逆時針方向連接每條平行線上的輸入點, 形成近似
13、 convex hull ai.第三步: 如果不再有點輸入 , 則停止; 否則令i=i+1, 接受下一 個點pi, goto 第一步.,時間復雜性O(mn)=O(n) (因為m是常數(shù))近似解精度三種相關的多邊形E: 由2m個平行線形成的多邊形.C: 輸入點集合的Convex hull, 即準確解.A: 算法A給出的近似Convex hull. L(P)表示
14、多邊形P的總邊長, 則L(E)?L(C)?L(A). 近似解A的誤差定義為 ERR(A)=(L(C)-L(A))/L(C),算法的性能分析,,,定理1. ERR(A)?sec(?/2m)-1. *定理1說明m越大(即平行線對越多), 錯誤越小. 證. 考慮下圖:,于是, AB+AC? BC sec(?/2).,,考慮下圖,,由AB+AC? BC sec(?/2),我
15、們有 L(E)= P2mA1+A1P1+P1A2+…+A2mP2m ? sec(? /2m)(P2mP1+P1P2+…+P2m-1P2m) = sec(? /2m)L(A). 于是, Err(A)= (L(C)-L(A))/L(C)
16、 ? (L(E)-L(A))/L(A) ? sec(? /2m)-1,10.4 Randomized On-line Algorithm for MST,問題的定義 隨機On-line算法 算法的性能分析,問題的定義,輸入 Euclidean空間上的n個點: v1, v2, …, vn n個逐個出現(xiàn) 輸出 由v1, v2, …, vn構成的最小生成樹,,Al
17、goritm R(m)T=0; input(m); input(v1); input(v2);把邊(v1, v2)添加到T;For k=3 To n Do input(vk); If k?m+1 Then 從(vk, v1), …,(vk, vk-1)中選擇最小邊加入T; Else 從(vk, v1)
18、, …,(vk, vk-1)中隨機地選擇m條邊, 把這m條邊中最小邊加入T;Return T.,隨機On-line算法,R(n-1)是一個確定的貪心算法,算法的時間復雜性,時間復雜性 每次考察需要O(m)時間 需要O(n)次考察 T(n)=O(nm),,近似解的精確度,定義1. 隨機On-line算法A稱為c-competitive, 如果存 在一個常數(shù)b
19、, 使得 E(CA(?)) ? c?Copt(?)+b 其中, E(CA(?))是算法A在問題實例?上產(chǎn)生的 近似解的代價, Copt(?)是?的優(yōu)化解的代價.定理1. 如果m是固定常數(shù), 算法R(m)的competitive, 則比是?(n). 證.,,我們首先定義一組記號: ?
20、={1, 2, …, n} 輸入點集合, 輸入順序為1、2、…、n. D(a, b) = 點a和b之間的距離. N(a, k) = 在已經(jīng)出現(xiàn)的點中點a的第k最近點. E(LR(m)(? )) = 算法R(m)產(chǎn)生的樹的期望長度. 假定算法收到第i個輸入點i. 如果2?i?m+1, 則i與前i-1個點中最近點連接, 加入樹中. 如果m+1?i?n, 則i與
21、前i-1個點中第j最近點連接的概率為,于是, 我們有,,我們來計算E(LR(m)(?))/L(?)的下界. L(?)是輸入點集合為?時的最小生成樹的長度.構造一個特殊輸入序列?*, 使得 E(LR(m)(?*))/L(?*)=?(n)于是, E(LR(m)(?))/L(?)=?(n)我們來計算E(LR(m)(?))/L(?)的上界.令D是n個輸入點的直徑. 最小生成樹的長度?D.因每條
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- [學習]算法設計與分析ch8隨機算法
- [學習]算法設計與分析ch7treesearchingstrateg
- [學習]算法設計與分析—遞歸算法
- [學習]算法分析與設計里的概率算法-概率算法
- [學習]算法設計與分析-作業(yè)-第4章
- 算法設計與分析
- [學習]算法設計與分析王佳01概述
- [學習]算法設計與分析-作業(yè)-第3章
- 10種機器學習算法的要點
- 算法分析與設計試卷
- 算法設計與分析復習
- [學習]算法導論let10-greedyalgorithm
- 算法分析與設計論文
- 《算法設計與分析》遞歸算法典型例題
- 算法設計與分析教案
- 算法設計與分析第05章貪心算法
- 算法設計與分析 動態(tài)規(guī)劃
- 《算法設計與分析》實驗指導
- 算法設計與分析習題輔導
- 算法設計與分析上機報告
評論
0/150
提交評論