算法設計和分析復習試題目及答案解析_第1頁
算法設計和分析復習試題目及答案解析_第2頁
算法設計和分析復習試題目及答案解析_第3頁
算法設計和分析復習試題目及答案解析_第4頁
算法設計和分析復習試題目及答案解析_第5頁
已閱讀5頁,還剩24頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、范文范例學習指導分治法1、二分搜索算法是利用(分治策略)實現(xiàn)的算法。9.實現(xiàn)循環(huán)賽日程表利用的算法是(分治策略)27、Strassen矩陣乘法是利用(分治策略)實現(xiàn)的算法。34.實現(xiàn)合并排序利用的算法是(分治策略 )0實現(xiàn)大整數(shù)的乘法是利用的算法(分治策略)。17.實現(xiàn)棋盤覆蓋算法利用的算法是(分治法 )029、使用分治法求解不需要滿足的條件是(子問題必須是一樣的)。不可以使用分治法求解的是(0/1背包問題)。動態(tài)規(guī)劃下列不是動態(tài)規(guī)劃算法基本步驟的是(構造最優(yōu)解)下列是動態(tài)規(guī)劃算法基本要素的是(子問題重疊性質)。下列算法中通常以自底向上的方式求解最優(yōu)解的是(動態(tài)規(guī)劃法)備忘錄方法是那種算法的變

2、形。(動態(tài)規(guī)劃法)最長公共子序列算法利用的算法是(動態(tài)規(guī)劃法)。矩陣連乘問題的算法可由(動態(tài)規(guī)劃算法 B)設計實現(xiàn)。實現(xiàn)最大子段和利用的算法是(動態(tài)規(guī)劃法)。貪心算法能解決的問題:單源最短路徑問題,最小花費生成樹問題,背包問題,活動安排問題,不能解決的問題:N皇后問題,0/1背包問題是貪心算法的基本要素的是(貪心選擇性質和最優(yōu)子結構性質)?;厮莘ɑ厮莘ń饴眯惺圬泦T問題時的解空間樹是(排列樹)0剪枝函數(shù)是回溯法中為避免無效搜索采取的策略回溯法的效率不依賴于下列哪些因素(確定解空間的時間)分支限界法最大效益優(yōu)先是(分支界限法)的一搜索方式。分支限界法解最大團問題時,活結點表的組織形式是( 最大堆)

3、。分支限界法解旅行售貨員問題時,活結點表的組織形式是( 最小堆)優(yōu)先隊列式分支限界法選取擴展結點的原則是(結點的優(yōu)先級)在對問題的解空間樹進行搜索的方法中,一個活結點最多有一次機會成為活結點 的是(分支限界法).從活結點表中選擇下一個擴展結點的不同方式將導致不同的分支限界法,以下除(棧式分支限界法)之外都是最常見的方式.(1)隊列式(FIFO)分支限界法:按照隊列先進先出(FIFO)原則選取下一個節(jié) 點為擴展節(jié)點。(2)優(yōu)先隊列式分支限界法:按照優(yōu)先隊列中規(guī)定的優(yōu)先級選取優(yōu)先級最高的節(jié)點成為當前擴展節(jié)點。(最優(yōu)子結構性質)是貪心算法與動態(tài)規(guī)劃算法的共同點。貪心算法與動態(tài)規(guī)劃算法的主要區(qū)別是(貪

4、心選擇性質 )?;厮菟惴ê头种藿绶ǖ膯栴}的解空間樹不會是 (無序樹).14.哈弗曼編碼的貪心算法所需的計算時間為(B)。A O (n2n)B O (nlogn)C、O (2n)D O (n)21、下面關于NP問題說法正確的是(B )A NP問題都是不可能解決的問題B P類問題包含在NP類問題中C NP完全問題是P類問題的子集D NP類問題包含在P類問題中40、背包問題的貪心算法所需的計算時間為( B)A O (n2n)B、O (nlogn)C、O (2n)D、O (n)42. 0-1背包問題的回溯算法所需的計算時間為( A)A O (n2n) B O (nlogn) C、O (2n) D O

5、 (n).47.背包問題的貪心算法所需的計算時間為(B)。A O (n2n) B O (nlogn) C、O (2n) D O (n)53 .采用貪心算法的最優(yōu)裝載問題的主要計算量在于將集裝箱依其重量從小到大排序,故算法的時間復雜度為(B )oA O (n2n) B O (nlogn) C、O (2n) D、O (n)56、算法是由若干條指令組成的有窮序列,而且滿足以下性質( D )(1)輸入:有0個或多個輸入(2) 輸出:至少有一個輸出(3)確定性:指令清晰,無歧義(4)有限性:指令執(zhí)行次數(shù)有限,而且執(zhí)行時間有限A (2)(3)B(1)(2)(4) C(1)(3)(4) D (2)(3)(4

6、)57、函數(shù)32n+10nlogn的漸進表達式是(B ).A. 2 n B. 32 n C. nlog n D. 10nlog n59、用動態(tài)規(guī)劃算法解決最大字段和問題,其時間復雜性為(B ).A.logn B.n C.n 2 D.nlogn61、設f(N),g(N)是定義在正數(shù)集上的正函數(shù),如果存在正的常數(shù)C和自然數(shù)N), 使得當N>N。時有f(N) &Cg(N),則稱函數(shù)f(N)當N充分大時有下界g(N),記作 f(N) Q(g(N),即 f(N)的階(A )g(N) 的階.A.不高于B.不低于C.等價于D.逼近二、填空題2、程序是 算法用某種程序設計語言的具體實現(xiàn)。3、算法

7、的“確定性”指的是組成算法的每條指令 是清晰的、無歧義的。6、算法是指解決問題的一種方法 或 一個過程 。7、從分治法的一般設計模式可以看出, 用它設計出的程序一般是 涕歸算法 。11、計算一個算法時間復雜度通??梢杂嬎阊h(huán)次數(shù)、基本操作的頻率或計算步。14、解決0/1背包問題可以使用動態(tài)規(guī)劃、回溯法和分支限界法,其中不需要排 序的是動態(tài)規(guī)劃,需要排序的是 回溯法 ,分支限界法。15、使用回溯法進行狀態(tài)空間樹裁剪分支時一般有兩個標準:約束條件和目標函數(shù)的界,N皇后問題和0/1背包問題正好是兩種不同的類型,其中同時使用約束 條件和目標函數(shù)的界進行裁剪的是0/1背包問題,只使用約束條件進行裁剪的是

8、 N 皇后問題。30.回溯法是一種既帶有系統(tǒng)性 又帶有跳躍性的搜索算法。33 .回溯法搜索解空間樹時,常用的兩種剪枝函數(shù)為約束函數(shù)和 限界函數(shù)。34 .任何可用計算機求解的問題所需的時間都與其規(guī)模 有關。35 .快速排序算法的性能取決于劃分的對稱性 。36 . Prim算法利用貪心策略求解最小生成樹 問題,其時間復雜度是 O(n 2。37 .圖的m著色問題可用回溯法求解,其解空間樹中葉子結點個數(shù)是mn ,解空間樹中每個內結點的孩子數(shù)是 m。38 若序列 X=B,C,A,D,B,C,D , Y=A,C,B,A,B,D,C,D,請給出序列 X 和 Y 的一 個最長公共子序列BABCD或cAbCD&

9、#163;CADCD39 用回溯法解問題時,應明確定義問題的解空間,問題的解空間至少應包含一個 (最優(yōu))解8.0-1背包問題的回溯算法所需的計算時間為o(n*2n),用動態(tài)規(guī)劃算法所需的計算時間為 o(minnc,2 n。二、綜合題(50分)1 .寫出設計動態(tài)規(guī)劃算法的主要步驟。問題具有最優(yōu)子結構性質;構造最優(yōu)值的遞歸關系表達式;3最優(yōu)值的算法描述;構造最優(yōu)解;2 .流水作業(yè)調度問題的johnson算法的思想。令N=i|a i<b,,=i|a i>=b;將N中作業(yè)按a的非減序排序得到N',將 N中作業(yè)按bi的非增序排序得到N'N'中作業(yè)接N2'中作業(yè)

10、就構成了滿 足Johnson法則的最優(yōu)調度。3 .若n=4,在機器 M1和M2上加工作業(yè)i所需的時間分別為 a和bi ,且 (ai,a2,a3,a4)=(4,5,12,10) , (bi,b 2,b3,b4)=(8,2,15,9) 求 4 個作業(yè)的最優(yōu)調度方 案,并計算最優(yōu)值。步驟為:N1=1, 3, N2=2, 4;N' =1, 3, N2' =4, 2;最優(yōu)值為:384 .使用回溯法解0/1背包問題:n=3, C=9, V=6,10,3 , W=3,4,4,其解空間有 長度為3的0-1向量組成,要求用一棵完全二叉樹表示其解空間 (從根出發(fā),左 1右0),并畫出其解空間樹,計

11、算其最優(yōu)值及最優(yōu)解。解空間為(0,0,0),(0,1,0),(0。1),(1。0),(0,1,1),(1。1),(1,1,0),(1,1,1)。解空間樹為:該問題的最優(yōu)值為:16最優(yōu)解為:(1,1, 0)5 .設S= X, X2, 一,X是嚴格遞增的有序集,利用二叉樹的結點來存儲S中的元素,在表示S的二叉搜索樹中搜索一個元素 X,返回的結果有兩種情形,(1) 在二叉搜索樹的內結點中找到 X=X,其概率為bio (2)在二叉搜索樹的葉結點中 確定XC (X, X+1),其概率為a。在表示S的二叉搜索樹T中,設存儲元素X 的結點深度為C;葉結點(X, X+1)的結點深度為di,則二叉搜索樹T的平均

12、路 長p為多少?假設二叉搜索樹Tij=X, X+1, 一,X最優(yōu)值為mij,Wij= ai-1+b+ +b+aj,貝U mij(1<=i<=j<=n)遞歸關系表達式為什么?nn二叉樹T的平均路長P=£ bi * (1+Ci) +Z aj* dji 1j=Smij=Wij+minmik+mk+1j (1<=i<=j<=n,mii-1=0)mij=0 (i>j)6 .描述0-1背包問題。已知一個背包的容量為C,有n件物品,物品i的重量為W,價值為V,求應如何選擇裝入背包中的物品,使得裝入背包中物品的總價值最大。三、簡答題(30分)1 .流水作業(yè)調

13、度中,已知有n個作業(yè),機器M1和M2上加工作業(yè)i所需的時間分 別為ai和bi,請寫出流水作業(yè)調度問題的johnson法則中對a和bi的排序算法。(函數(shù)名可寫為sort(s,n)2 .最優(yōu)二叉搜索樹問題的動態(tài)規(guī)劃算法(設函數(shù)名 binarysearchtree)1.void sort(flowjope s口,int n)int i,k,j,l;for(i=1;i<=n-1;i+)/ 選擇排序 k=i;while(k<=n&&sk.tag!=0) k+;if(k>n) break;/沒有 a ,跳出elsefor(j=k+1;j<=n;j+)if(sj.ta

14、g=0)if(sk.a>sj.a) k=j;swap(si.index,sk.index); swap(si.tag,sk.tag); l=i;/記下當前第一個bi的下標for(i=l;i<=n-1;i+) k=i;for(j=k+1;j<=n;j+)if(sk.b<sj.b) k=j;swap(si.index,sk.index); / 只移動 index 和 tagswap(si.tag,sk.tag); 2.void binarysearchtree(int a口,int b口,int n,int *m,int *s,int *w)int i,j,k,t,l;fo

15、r(i=1;i<=n+1;i+) wii-1=ai-1;mii-1=0;for(l=0;l<=n-1;l+)/-1是下標 j-i 的差for(i=1;i<=n-1;i+) j=i+1;wij=wij-1+aj+bj;mij=mii-1+mi+1j+wij;sij=i;for(k=i+1;k<=j;k+) t=mik-1+mk+1j+wij;if(t<mij) mij=t;sij=k;一、 填空題(本題15分,每小題1分)1、算法就是一組有窮的 規(guī)則,它們規(guī)定了解決某一特定類型問題的一系列運算2、在進行問題的計算復雜性分析之前,首先必須建立求解問題所用的計算模 型。

16、3個基本計算模型是隨機存取機 RAM 、隨機存取存儲程序機RASP、 圖靈機 。3、算法的復雜性是算法效率的度量,是評價算法優(yōu)劣的重要依據(jù)。4、計算機的資源最重要的是時間 和 空間 資源5、f(n尸 6 X2n+n2, f(n)的漸進性態(tài) f(n)= O(2An)6、貪心算法總是做出在當前看來最好的選擇。也就是說貪心算法并不從整體最優(yōu)考慮,它所做出的選擇只是在某種意義上的局部最優(yōu)結構二、簡答題(本題25分,每小題5分)1、 簡單描述分治法的基本思想。2、 簡述動態(tài)規(guī)劃方法所運用的最優(yōu)化原理。3、 何謂最優(yōu)子結構性質?4、 簡單描述回溯法基本思想。5、 何i胃P、NP NPC問題三、算法填空(本

17、題20分,每小題5分)1、n后問題回溯算法(1)用二維數(shù)組ANN存儲皇后位置,若第i行第j列放有皇后,則Aij 為 非0值,否則值為00(2)分別用一維數(shù)組 MN、L2*N-1、R2*N-1表示豎列、左斜線、右斜線是否放有棋子,有則值為1,否則值為00for(j=0;j<N;j+)if( 1) /* 安全檢查*/ Aij=i+1; /* 放皇后*/if(i=N-1)輸出結果;else 3; ; /* 試探下一行 */4;/* 去皇后*/2、數(shù)塔問題。有形如下圖所示的數(shù)塔,從頂部出發(fā),在每一結點可以選擇向左走或是向右走,一起走到底層,要求找出一條路徑,使路徑上的值最大。for(r=n-2;

18、r>=0;r-) 自底向上遞歸計算for(c=0; 1;c+)if( tr+1c>tr+1c+1)2 else 3 ;3、Hanoi 算法Hanoi(n,a,b,c)if (n=1) J ; elseHanoi(n-1,b, a, c);4、Dijkstra 算法求單源最短路徑du:s到u的距離pu:記錄前一節(jié)點信息Init-single-source(G,s)for each vertex v VGdo dv=8 ; 1ds=0Relax(u,v,w)if dv>du+w(u,v) then dv=du+wu,v;2 dijkstra(G,w,s) 1. Init-sing

19、le-source(G,s) 2. S= 3. Q=VG 4.while Q<> do u=min(Q) S=S U u for each vertex 3do 4四、算法理解題(本題10分) 根據(jù)優(yōu)先隊列式分支限界法,求 下圖中從v1點到v9點的單源最 短路徑,請畫出求得最優(yōu)解的解 空間樹。要求中間被舍棄的結點 用x標記,獲得中間解的結點用 單圓圈??蚱?,最優(yōu)解用雙圓圈 框起。五、算法理解題(本題5分)設有n=2k個運動員要進行循環(huán)賽,現(xiàn)設計一個滿足以下要求的比賽日程表:每個選手必須與其他n-1名選手比賽各一次;每個選手一天至多只能賽一次;循環(huán)賽要在最短時間內完成。(1)如果n=

20、2k,循環(huán)賽最少需要進行幾天;(2)當n=23=8時,請畫出循環(huán)賽日程表。六、算法設計題(本題15分)分別用貪心算法、動態(tài)規(guī)劃法、回溯法設計 0-1背包問題。要求:說明所使 用的算法策略;寫出算法實現(xiàn)的主要步驟;分析算法的時間。七、算法設計題(本題10分)通過鍵盤輸入一個高精度的正整數(shù) n(n的有效位數(shù)0 240),去掉其中任意s 個數(shù)字后,剩下的數(shù)字按原左右次序將組成一個新的正整數(shù)。編程對給定的n和 s,尋找一種方案,使得剩下的數(shù)字組成的新數(shù)最小?!緲永斎搿?78543S=4【樣例輸出】13二、簡答題(本題25分,每小題5分)6、分治法的基本思想是將一個規(guī)模為n的問題分解為k個規(guī)模較小的子

21、問題, 這些子問題互相獨立且與原問題相同;對這k個子問題分別求解。如果子問題的規(guī)模仍然不夠小,則再劃分為 k個子問題,如此遞歸的進行下去, 直到問題規(guī)模足夠小,很容易求出其解為止;將求出的小規(guī)模的問題的解 合并為一個更大規(guī)模的問題的解,自底向上逐步求出原來問題的解。7、“最優(yōu)化原理”用數(shù)學化的語言來描述:假設為了解決某一優(yōu)化問題,需 要依次作出n個決策D1, D2,Dn,如若這個決策序列是最優(yōu)的,對于 任何一個整數(shù)k, 1 < k < n ,不論前面k個決策是怎樣的,以后的最優(yōu)決 策只取決于由前面決策所確定的當前狀態(tài),即以后的決策Dk+1, Dk+2,Dn也是最優(yōu)的。8、某個問題的

22、最優(yōu)解包含著其子問題的最優(yōu)解。這種性質稱為最優(yōu)子結構性質。9、回溯法的基本思想是在一棵含有問題全部可能解的狀態(tài)空間樹上進行深度 優(yōu)先搜索,解為葉子結點。搜索過程中,每到達一個結點時,則判斷該結 點為根的子樹是否含有問題的解, 如果可以確定該子樹中不含有問題的解, 則放棄對該子樹的搜索,退回到上層父結點,繼續(xù)下一步深度優(yōu)先搜索過 程。在回溯法中,并不是先構造出整棵狀態(tài)空間樹,再進行搜索,而是在 搜索過程,逐步構造出狀態(tài)空間樹,即邊搜索,邊構造。10、 P(Polynomial問題):也即是多項式復雜程度的問題。NP就是Non-deterministic Polynomial的問題,也即是多項式復

23、雜程度 的非確定性問題。word完美整理版NPC(NP Complete)問題,這種問題只有把解域里面的所有可能都窮舉了之后才能得出答案,這樣的問題是 題。NP里面最難的問題,這種問題就是 NPC訶三、算法填空(本題20分,每小題5分) 1、n后問題回溯算法(1) !Mj&&!Li+j&&!Ri-j+N(2) Mj=Li+j=Ri-j+N=1; try(i+1,M,L,R,A) Aij=0(5) Mj=Li+j=Ri-j+N=02、數(shù)塔問題。(1) c<=r(2)trc+=tr+1c(3) trc+=tr+1c+13、Hanoi 算法(1) move(a,

24、c)(2) Hanoi(n-1, a, c , b)(3) Move(a,c)4、(1) pv=NIL(2) pv=u(3) v C adju(4) Relax(u,v,w)四、算法理解題(本題10分)五、(1) 8天(2分);(2)當n=23=8時,循環(huán)賽日程表(六、算法設計題(本題15分)(1)貪心算法 O (nlog (n)3分)1 2 3 42 1 4 33 4 1 24 3 2 15 6 7 86 5 8 77 8 5 68 7 6 55 6 7 86 5 8 77 8 5 68 7 6 51 2 3 42 1 4 33 4 1 24 3 2 1首先計算每種物品單位重量的價值 Vi/

25、Wi ,然后,依貪心選擇策略,將盡 可能多的單位重量價值最高的物品裝入背包。 若將這種物品全部裝入背包 后,背包內的物品總重量未超過 C,則選擇單位重量價值次高的物品并盡 可能多地裝入背包。依此策略一直地進行下去,直到背包裝滿為止。具體算法可描述如下:void Knapsack(int n,float M,float v,float w,float x口)Sort(n,v,w);int i;for (i=1;i<=n;i+) xi=0;float c=M;for (i=1;i<=n;i+)if (wi>c) break;xi=1;c-=wi;if (i<=n) xi=c

26、/wi;(2)動態(tài)規(guī)劃法O(nc)m(i, j)是背包容量為j ,可選擇物品為i , i+1 ,,n時0-1背包問題的最 優(yōu)值。由0-1背包問題的最優(yōu)子結構性質,可以建立計算m(i,j)的遞歸式如下。,maxm(i+1, j),m(i+1, j -w)+m j 之 Wim(i, j)=m(i +1, j)0 < j < wiVn m(n, j) - 0j -Wn0 三 j : Wnvoid KnapSack(int v口,int w口,int c,int n,int m11) int jMax=min(wn-1,c);for (j=0;j<=jMax;j+) /*m(n,j)

27、=0 0=<j<wn*/ mnj=0;for (j=wn;j<=c;j+) /*m(n,j)=vn j>=wn*/ mnj=vn;for (i=n-1;i>1;i-) int jMax=min(wi-1,c);for (j=0;j<=jMax;j+) /*m(i,j)=m(i+1,j) 0=<j<wi*/ mij=mi+1j;for (j=wi;j<=c;j+)/*m(n,j)=vn j>=wn*/ mij=max(mi+1j,mi+1j-wi+vi);m1c=m2c;if(c>=w1)m1c=max(m1c,m2c-w1+v1

28、);回溯法O(2 n)cw:當前重量 cp: 當前價值 bestp :當前最優(yōu)值 void backtrack( int i)/回溯法 i初值1if(i > n) /到達葉結點 bestp = cp;return;if(cw + wi <= c) / 搜索左子樹 cw += wi;cp += pi;backtrack(i+1);cw -= wi;cp = pi; if(Bound(i+1)>bestp)/搜索右子樹backtrack(i+1);七、算法設計題(本題10分)為了盡可能地逼近目標,我們選取的貪心策略為:每一步總是選擇一個使剩下的數(shù)最小的數(shù)字刪去,即按高位到低位的順

29、序搜索,若各位數(shù)字遞增,則刪 除最后一個數(shù)字,否則刪除第一個遞減區(qū)間的首字符。然后回到用首,按上述規(guī)則再刪除下一個數(shù)字。重復以上過程 s次,剩下的數(shù)字用便是問題的解了。具體算法如下:輸入s, n;while ( s > 0) i=1; /從用首開始找while (i < length(n) && (ni<ni+1)i+;delete(n,i,1); /刪除字符串n的第i個字符s-;while (length(n)>1)&&(n1= '0')delete(n,1,1); / 刪去用首可能產生的無用零輸出n;三、算法填空1 .

30、背包問題的貪心算法void Knapsack(int n,float M,float v,float w,float x口)Sort(n,v,w);int i;for (i=1;i<=n;i+) xi=0;float c=M;for (i=1;i<=n;i+) if (wi>c) break;xi=1;c - =wi;if (i<=n) xi=c/wi;2 .最大子段和:動態(tài)規(guī)劃算法int MaxSum(int n, int a口)int sum=0, b=0; /sum存儲當前最大的 bj, b 存儲 bjfor(int j=1; j<=n ; j+) if (

31、b>0) b+= aj;else b=ai;/一旦某個區(qū)段和為負,則從下一個位置累和if(b>sum) sum=b;return sum ;3 .快速排序template<class Type>void QuickSort (Type a口,int p, int r)if (p<r) int q=Partition(a,p,r);Quicksort (a,p,q-1); 對左半段排序Quicksort (a,q+1,r); 對右半段排序4 . IF歹I問題Template <class Type>void perm(Type list, int k,

32、int m )/產生listk:m的所有排列if(k=m)_ /只剩下一個元素for (int i=0;i<=m;i+) cout<<listi;cout<<endl;else /還有多個元素待排列,遞歸產生排列for (int i=k; i<=m; i+)swap(listk, listi);perm(list,k+1;m);swap(listk,listi);5 .給定已按升序排好序的n個元素a0:n-1,現(xiàn)要在這n個元素中找出一特定 元素X。據(jù)此容易設計出二分搜索算法:template<class Type>int BinarySearch

33、(Type a口,const Type& x, int l, int r)while (l<=r )int m = (l+r)/2);if (x = am) return m;if (x < am) r = m-1; else l = m+1;return -1;6、合并排序描述如下:template<class Type>void Mergesort(Type a , int left, int right)if ( left<right )int i=( left+right)/2;Mergesort(a, left, i );Mergesort(a,

34、 i+1, right);合并到數(shù)組b復制到數(shù)組aMerge(a,b, left,i,right);/Copy(a,b, left,right ); /7、以下是計算xm的值的過程int power ( x, m )/計算xm的值并返回。y=( 1 );i=m;While(i- - >0)y=y*x; (return y) ;四、問答題1 .用計算機求解問題的步驟:1、問題分析2、數(shù)學模型建立3、算法設計與選擇4、算法指標5、算法分析6、算法實現(xiàn)7、程序調試8、結果整理文檔編制2 .算法定義:算法是指在解決問題時,按照某種機械步驟一定可以得到問題結果的處理過 程3 .算法的三要素1、操作

35、2、控制結構3、數(shù)據(jù)結構13 .分治法與動態(tài)規(guī)劃法的相同點是:將待求解的問題分解成若干個子問題,先求解子問題,然后從這些子問題的 解得到原問題的解。兩者的不同點是:適合于用動態(tài)規(guī)劃法求解的問題,經分解得到的子問題往 往不是互相獨立的。而用分治法求解的問題,經分解得到的子問題往往是互相獨 立的?;厮莘ㄖ谐R姷膬深惖湫偷慕饪臻g樹是子集樹和排列樹。22 .請敘述動態(tài)規(guī)劃算法與貪心算法的異同。共同點:都需要最優(yōu)子結構性質,都用來求有優(yōu)化問題。不同點:動態(tài)規(guī)劃:每一步作一個選擇一依賴于子問題的解。貪心方法:每一步作一個選擇一不依賴于子問題的解 。動態(tài)規(guī)劃方法的條件:子問題的重疊性質??捎秘澬姆椒ǖ臈l件:

36、最優(yōu)子結構性質;貪心選擇性質。動態(tài)規(guī)劃:自底向上求解;貪心方法:自頂向下求解??捎秘澬姆〞r,動態(tài)規(guī)劃方法可能不適用;可用動態(tài)規(guī)劃方法時,貪心法可能不適用。23 .請說明動態(tài)規(guī)劃方法為什么需要最優(yōu)子結構性質。答:最優(yōu)子結構性質是指大問題的最優(yōu)解包含子問題的最優(yōu)解。動態(tài)規(guī)劃方法是自底向上計算各個子問題的最優(yōu)解,即先計算子問題的最優(yōu)解,然后再利用子問題的最優(yōu)解構造大問題的最優(yōu)解,因此需要最優(yōu)子結構. 24.請說明:(1)優(yōu)先隊列可用什么數(shù)據(jù)結構實現(xiàn)?優(yōu)先隊列插入算法基本思想?(3)優(yōu)先隊列插入算法時間復雜度?答:(1)堆。(2)在小根堆中,將元素x插入到堆的末尾,然后將元素x的關鍵字與其雙親的關鍵字

37、比較,若元素x的關鍵字小于其雙親的關鍵字,則將元素x與其雙親交換,然后再將元素x與其新雙親的關鍵字相比, 直到元素x的關鍵字大于雙親的關鍵字,或元素 x到根為止。(3) O( log n)26.在算法復雜性分析中, O Q、這三個記號的意義是什么?在忽略常數(shù) 因子的情況下,O Q、分別提供了算法運行時間的什么界?答:如果存在兩個正常數(shù)c和N0,對于所有的N> ND,有|f(M &qg(N ,則記作:f(N= qg(N)。這時我們說f(N)的階不高于g(N)的階。若存在兩個正常數(shù)C和自然數(shù)NO,使彳馬當N > N0時有|f(N)| >C|g(N)| ,記為 f(N=?

38、(g(N)。這時我們說f(N)的階不低于g(N)的階。如果存在正常數(shù) cl, c2和nO,對于所有的nnO,有c1|g(N)| < |f(N)|<c2|g(N)|則記作 f(N= (g,( N)O。、日分別提供了算法運行時間的上界、下界、平均五、算法設計與分析題1 .用動態(tài)規(guī)劃策略求解最長公共子序列問題:(1)給出計算最優(yōu)值的遞歸方程。(2)給定兩個序列X=B,C,D,A , Y=A,B,C,B,請采用動態(tài)規(guī)劃策略求出其最長公共子序列,要求給出過程。答:10ci, j=悶i -1,j -1 +1 ,max(ci, j -1, ci當i = 0或j= 0時當i, j > 0且x

39、 i = yi時-1,j)當i, j >。且x i ¥ yi 時Y A B C BXBCDA00001012t最長公共子序列: B C g(n)=n!g (n)=log n f(n)=100 ; f(n)=n 3;(5) f(n)=3 n;g(n)=log100g(n)= 3g(n)=22 .對下列各組函數(shù) f (n)和 g (n),確定 f (n) = O(g (n)或 f (n) =Q (g (n)或f(n) = 0 (g(n),并簡要說明理由(1) f(n)=2;(1)f(n) = O(g(n)(2)f(n) =Q (g(n)f(n) =o (g(n)因為g(n)的階比f

40、(n)的階高 因為g(n)的階比f(n)的階低 因為g(n)與f(n)同階。(4)f(n) = O(g(n)(5)f(n) = Q (g(n)因為g(n)的階比f(n)的階高因為g(n)的階比f(n)的階低3.對下圖所示的連通網絡G,用克魯斯卡爾(Kruskal)算法求G的最小生成樹T,請寫出在算法執(zhí)行過程中,依次加入 T的邊集TE中的邊。說明該算法的貪心策略和算法的基本思想,并簡要分析算法的時間復雜度 f(n)= Jn ;TE=(3,4), (2,3),(1,5),(4,6) (4,5) 貪心策略是每次都在連接兩個不同連通分量的邊中選權值最小的邊。基本思想:首先將圖中所有頂點都放到生成樹中,

41、然后每次都在連接兩個不同連通分量的邊中選權值最小的邊,將其放入生成樹中,直到生成樹中有n-1 條邊。時間復雜度為:O(eloge)4.請用分治策略設計遞歸的歸并排序算法,并分析其時間復雜性(要求:分別 給出divide、conquer、combine這三個階段所花的時間,并在此基礎上列出遞 歸方程,最后用套用公式法求出其解的漸進階)。答 : Template <class Type>void MergeSort (Type a , int left, int right) if (left<right) int i=(left+right )MergeSort (a, lef

42、t, i );MergeSort (a, i+1, right );Merge(a, b, left, right);Copy(a, b, left, right);Divide階段的時間復雜性:O(1)Conquer階段的時間復雜性:2T(n)Combine階段的時間復雜性:(9(n)T(n)河2T(n/2) + 9 (n)用套用公式法:a=2, b=2, n log ba = n , f(n)=n, 因為 f(n)與 nlog ba 同階, .T(n) = O(nlogn)1 2 3 4 5 6 71234567821436587341278564321876556781234658721

43、4378563412876543215、設有n=2k個運動員要進行循環(huán)賽,現(xiàn)設計一個滿足以下要求的比賽日程表: 每個選手必須與其他n-1名選手比賽各一次;每個選手一天至多只能賽一次; 循環(huán)賽要在最短時間內完成.(1) (4分)循環(huán)賽最少需要進行(n-1)天.(2) (6分)當n=23=8時,請畫出循環(huán)賽日程表:6、考慮用哈夫曼算法來找字符a,b,Gd,e,f的最優(yōu)編碼。這些字符出現(xiàn)在文件中的頻數(shù)之比為20:10:6:4:44:16。要求:(1) (4分)簡述使用哈夫曼算法構造最優(yōu)編碼的基本步驟;(2) (5分)構造對應的哈夫曼樹,并據(jù)此給出a,b,c,d,e,f的一種最優(yōu)編碼。解:1)、哈夫曼算法是構造最優(yōu)編碼樹的貪心算法。其基本思想是,首先所 有字符對應n棵樹構成的森林,每棵樹只有一個結點,根權為對應字符的頻率。 然后,重復下列過程n-1次:將森林中的根權最小的兩棵樹進行合并產生一個新樹,該新樹根的兩

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論