算法設(shè)計(jì)與分析課件_第1頁(yè)
算法設(shè)計(jì)與分析課件_第2頁(yè)
算法設(shè)計(jì)與分析課件_第3頁(yè)
算法設(shè)計(jì)與分析課件_第4頁(yè)
算法設(shè)計(jì)與分析課件_第5頁(yè)
已閱讀5頁(yè),還剩167頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

算法設(shè)計(jì)與分析云南大學(xué)廖鴻志2024/12/292內(nèi)容計(jì)算模型和計(jì)算復(fù)雜性的測(cè)度數(shù)據(jù)結(jié)構(gòu)與遞歸技術(shù)分治與平衡排序動(dòng)態(tài)規(guī)劃貪心法回溯法分枝限界法2024/12/293第一章計(jì)算模型和計(jì)算復(fù)雜性的測(cè)度2024/12/2941.1引言1.算法的概念基本上幾乎所有的程序都是為了實(shí)現(xiàn)某種算法,簡(jiǎn)言之算法就是處理問(wèn)題的步驟與邏輯,它是有窮規(guī)則的有序集合。算法分為數(shù)值算法與非數(shù)值算法。數(shù)值算法有:概率統(tǒng)計(jì)計(jì)算、線性代數(shù)計(jì)算、數(shù)值逼近、數(shù)值微分、數(shù)值積分、數(shù)學(xué)規(guī)劃等。數(shù)值算法是通用的,一般可用解析式表示:而非數(shù)值算法只是思想或思路,要根據(jù)具體問(wèn)題按這種思想或思路進(jìn)行設(shè)計(jì)。2024/12/2951.1引言2算法的特征(1)有窮性:算法應(yīng)該是有窮規(guī)則,在有窮步驟后終止。(2)確定性:算法的任何一步都應(yīng)該有且僅有一個(gè)解釋。(3)能行性:算法應(yīng)該符合問(wèn)題的要求,應(yīng)該在有限時(shí)間內(nèi)完成。(4)輸入與輸出:有零個(gè)或多個(gè)外部量作為算法的輸入,算法產(chǎn)生至少一個(gè)量作為輸出。2024/12/2961.1引言程序與算法不同,程序是算法用某種程序設(shè)計(jì)語(yǔ)言的具體實(shí)現(xiàn)。程序可以不滿足算法的有限性。例如操作系統(tǒng),它是在無(wú)限循環(huán)中執(zhí)行的程序,因而它并不是算法。然而可以將它的各種任務(wù)看成一些單獨(dú)的問(wèn)題。每一個(gè)問(wèn)題由操作系統(tǒng)的一個(gè)子程序通過(guò)特定的算法實(shí)現(xiàn)。該子程序在得出輸出結(jié)果后便終止。2024/12/2971.1引言3算法設(shè)計(jì)與分析的步驟(1)問(wèn)題的描述:明確輸入與輸出。(2)建立模型:將核心內(nèi)容模型化,邏輯化。(3)算法設(shè)計(jì)與正確性證明:對(duì)所有正確的輸入都能得到正確的輸出(一般需要用謂詞邏輯來(lái)證明)。(4)程序?qū)崿F(xiàn):用某種程序設(shè)計(jì)語(yǔ)言來(lái)實(shí)現(xiàn)。(5)算法分析:在程序?qū)崿F(xiàn)之前進(jìn)行。2024/12/2981.2計(jì)算復(fù)雜性的測(cè)度算法的計(jì)算復(fù)雜性(computationalcomplexity)是衡量算法計(jì)算難度的尺度,使用最普遍的標(biāo)準(zhǔn)是一個(gè)算法需要耗費(fèi)的時(shí)間和空間。算法所需要的時(shí)間或空間,通常是問(wèn)題規(guī)模的函數(shù),這個(gè)函數(shù)就叫做算法的時(shí)間或空間復(fù)雜度。在實(shí)際中用算法主操作的重復(fù)次數(shù)來(lái)表示算法的時(shí)間復(fù)雜度。2024/12/2991.2計(jì)算復(fù)雜性的測(cè)度問(wèn)題的規(guī)模:也就是該問(wèn)題所謂的體積,或者說(shuō)是大小。一個(gè)問(wèn)題的體積可以用一個(gè)整數(shù)來(lái)表示,它是對(duì)問(wèn)題的輸入數(shù)據(jù)或初始數(shù)據(jù)的多少的一種量度。定義:如果一個(gè)問(wèn)題的體積是n,解決這一問(wèn)題的某一算法所需要的時(shí)間為T(n),它是n的某一函數(shù),T(n)稱作這一算法的“時(shí)間復(fù)雜性”。當(dāng)輸入量n逐漸增大時(shí),T(n)的極限情形就稱作算法的“漸近時(shí)間復(fù)雜性”,類似可定義算法的空間復(fù)雜性。但實(shí)際上人們主要是研究算法的時(shí)間復(fù)雜性而很少討論它們的空間耗費(fèi)。2024/12/29101.2計(jì)算復(fù)雜性的測(cè)度一個(gè)算法的復(fù)雜性函數(shù)的量級(jí)是反映算法效能的重要標(biāo)準(zhǔn)。當(dāng)輸入量急劇地增大時(shí),如果設(shè)有高效能的算法,單純依靠提高計(jì)算機(jī)的速度,有時(shí)是很不理想的。設(shè)有五個(gè)算法A1,A2,A3,A4,A5,它們的時(shí)間復(fù)雜性函數(shù)如下表所示:表中,一個(gè)算法的時(shí)間復(fù)雜性是它處理完一個(gè)大小為n的輸入所需要的的單位時(shí)間數(shù)。2024/12/2911例例1.39個(gè)景點(diǎn)的全排列

39!=2.04×1046

用每秒處理1億次(108)邏輯的計(jì)算機(jī),需耗時(shí)6.5×1022億年例2.下圍棋

3361=1.74×10172=5.52×10146億年例3.電梯從1樓到10樓,有多少種可能的方式?

2024/12/2912算法時(shí)間復(fù)雜性函數(shù)A1T1(n)=nA2T2(n)=nlog2n(nlogn)A3T3(n)=n2A4T4(n)=n3A5T5(n)=2?1.2計(jì)算復(fù)雜性的測(cè)度2024/12/2913算法時(shí)間復(fù)雜性一秒鐘內(nèi)所能處理的最大輸入量一分鐘內(nèi)所能處理的最大輸入量一小時(shí)內(nèi)所能處理的最大輸入量A1A2A3A4A5nn㏒2nn2n32?1000140311096×104489324439153.6×1062.0×1051897153211.2計(jì)算復(fù)雜性的測(cè)度2024/12/2914算法時(shí)間復(fù)雜性速度提高前單位時(shí)間里所能處理的數(shù)據(jù)量速度提高十倍后單位時(shí)間里所能處理的數(shù)據(jù)量速度提高一萬(wàn)倍后單位時(shí)間里所能處理的數(shù)據(jù)量A1A2A3A4A5nn㏒2nn2n32?S1S2S3S4S510S1(S2很大)10S23.16S32.15S4S5+3.3210000S1(㏒2S2≥9㏒29000)>9000S2100S321.54S4S5+13.321.2計(jì)算復(fù)雜性的測(cè)度2024/12/29151.2計(jì)算復(fù)雜性的測(cè)度現(xiàn)有問(wèn)題可以分為以下三類:無(wú)法寫出算法的問(wèn)題;有以多項(xiàng)式為界的算法存在的問(wèn)題,即P類問(wèn)題;介于前兩類問(wèn)題之間的問(wèn)題,“NP——完全”問(wèn)題。2024/12/29161.3隨機(jī)存取模型自學(xué)2024/12/2917第二章數(shù)據(jù)結(jié)構(gòu)和遞歸技術(shù)2024/12/2918表、樹(shù)、圖表:a1,a2,a3,…,ai,ai+1,…an是一個(gè)數(shù)據(jù)元素,ai-1為ai的前驅(qū),ai+1為其后繼。第一個(gè)元素沒(méi)有前驅(qū),最后一個(gè)數(shù)據(jù)元素沒(méi)有后繼。順序存儲(chǔ):數(shù)組鏈?zhǔn)酱鎯?chǔ):鏈表2024/12/29192.1圖和圖的表示鄰接矩陣鄰接表鄰接向量關(guān)聯(lián)矩陣一般有以上幾種圖的常用表示法2024/12/29202.2樹(shù)僅有一個(gè)沒(méi)有邊進(jìn)入的頂點(diǎn),這個(gè)頂點(diǎn)稱為這棵樹(shù)的根;除根以外的其它任何頂點(diǎn),有且只有一條邊進(jìn)入該頂點(diǎn);從根到每一個(gè)頂點(diǎn)都有一條唯一的道路。2024/12/29212.2樹(shù)二叉樹(shù):根最多有兩個(gè)孩子,若有左子,左孩子為二叉樹(shù);若有右孩子,右孩子為二叉樹(shù)。完全二叉樹(shù):結(jié)點(diǎn)深度最多差1,除沒(méi)有孩子的結(jié)點(diǎn)所在層為滿二叉樹(shù),沒(méi)有孩子的結(jié)點(diǎn)集中在左邊。滿二叉樹(shù):所有葉片的深度都相等的完全二叉樹(shù)。2024/12/29222.2樹(shù)樹(shù)的遍歷先序遍歷中序遍歷后序遍歷2024/12/29232.3遞歸技術(shù)一個(gè)直接或間接地調(diào)用自身的過(guò)程稱為遞歸過(guò)程(recursiveprocedure);一個(gè)直接或間接地調(diào)用自身的算法稱為遞歸算法。一個(gè)使用函數(shù)自身給出定義的函數(shù)叫做遞歸函數(shù)(recursivefunction)。在算法設(shè)計(jì)與分析中,使用遞歸技術(shù)往往使函數(shù)的定義和算法的描述簡(jiǎn)潔且易于理解。有些數(shù)據(jù)結(jié)構(gòu)如二叉樹(shù)等,由于其本身固有的遞歸特性,特別適合用遞歸的形式來(lái)描述。還有一些問(wèn)題,雖然其本身并沒(méi)有明顯的遞歸結(jié)構(gòu),但用遞歸技術(shù)來(lái)求解使設(shè)計(jì)出的算法簡(jiǎn)潔易懂且易于分析。2024/12/29242.3遞歸技術(shù)例2.5階乘函數(shù)階乘函數(shù)可以遞歸地定義為:2024/12/29252.3遞歸技術(shù)定義式的左右兩邊都引用了階乘記號(hào),是一個(gè)遞歸定義式,可遞歸地計(jì)算如下:intFactorial(intn){ if(n==0) return1; else returnn*Factorial(n-1);}2024/12/29262.3遞歸技術(shù)例2.6Fibonacci數(shù)列無(wú)窮數(shù)列1,1,2,3,5,8,13,21,34,55,...,稱為Fibonacci數(shù)列或級(jí)數(shù)。它可以遞歸地定義為:2024/12/29272.3遞歸技術(shù)第n個(gè)Fibonacci數(shù)可以遞歸地計(jì)算如下:intFibonacci(intn){ if(n≤1) return1; else returnFibonacci(n-1)+Fibonacci(n-2);}2024/12/29282.3遞歸技術(shù)上述兩例中的函數(shù)也可以用如下的非遞歸方式定義:2024/12/29292.3遞歸技術(shù)并非一切遞歸函數(shù)都能用非遞歸方式定義。為了對(duì)遞歸函數(shù)的復(fù)雜性有更多的了解,我們?cè)俳榻B一個(gè)雙遞歸函數(shù)——Achkerman函數(shù)。當(dāng)一個(gè)函數(shù)及它的一個(gè)變量是由函數(shù)自身定義時(shí),稱這個(gè)函數(shù)是雙遞歸函數(shù)。2024/12/29302.3遞歸技術(shù)Acheman函數(shù)A(n,m)有兩個(gè)獨(dú)立的整變量m≥0和n≥0,其定義如下:

2024/12/29312.3遞歸技術(shù)A(n,m)的自變量m的每一個(gè)值都定義了一個(gè)單變量函數(shù)。由遞歸式的第三式可知m=0定義了函數(shù)“加2”。當(dāng)m=1時(shí),由于A(1,1)=A(A(0,1),0)=A(1,0)=2以及A(n,1)=A(A(n-1,1),0)=A(n-1,1)+2(n>1),則A(n,1)=2n(n≥1),即A(n,1)是函數(shù)“乘2”當(dāng)m=2時(shí)由于A(n,2)=A(A(n-1,2),1)=2A(n-1,2)以及A(1,2)=A(A(0,2),1)=A(1,1)=2,則有A(n,2)=2的n次方2024/12/29322.3遞歸技術(shù)大家可以試著算一下A(2,10)和A(3,4)答案分別是:222```2}10個(gè)2222```2}65536個(gè)22024/12/29332.3遞歸技術(shù)2.3.1整數(shù)劃分把一個(gè)正整數(shù)n表示成如下形式的一系列正整數(shù)的和,叫做n的一個(gè)劃分。2024/12/29342.3遞歸技術(shù)正整數(shù)n的不同劃分個(gè)數(shù)稱為正整數(shù)n的劃分?jǐn)?shù),記作P(n),P(n)是一個(gè)數(shù)論函數(shù)。例如:正整數(shù)6有如下11種不同的劃分,所以P(6)=11。這11個(gè)劃分分別是:6;5+1;4+2,4+1+1;3+3,3+2+1,3+1+1+1;2+2+2,2+2+1+1,2+1+1+1+1;1+1+1+1+1+1。2024/12/29352.3遞歸技術(shù)

將最大加數(shù)n1不大于m的劃分個(gè)數(shù)記作Q(m,n)。我們可以建立如下的遞歸關(guān)系。Q(n,1)=1,n≥1;當(dāng)最大加數(shù)n1不大于1時(shí),任何正整數(shù)n只是有種切分形式,即n=1+1+...+1,n個(gè)1相加。Q(n,m)=Q(n,n),m≥n;最大加數(shù)n1實(shí)際上不能大于n。因此,Q(1,m)=1。Q(n,n)=1+Q(n,n-1);正整數(shù)n的劃分由n1=n的劃分和n1≤n-1的劃分組成。Q(n,m)=Q(n,m-1)+Q(n-m,m),n>m>1;正整數(shù)n的最大加數(shù)n1不大于m的劃分由n1=m的劃分和n1≤m-1的劃分組成。2024/12/29362.3遞歸技術(shù)以上的關(guān)系實(shí)際上給出了計(jì)算Q(n,m)的遞歸式如下:2024/12/29372.3遞歸技術(shù)可以設(shè)計(jì)出計(jì)算Q(n,m)的遞歸算法如下:intQ(intn,intm){ if((n<1)||(m<1)) return0; if((n==1)||(m==1)) return1; if(n<m) returnQ(n,n); if(n==m) returnQ(n,m-1)+1; else returnQ(n,m-1)+Q(n-m,m);}2024/12/29382.3遞歸技術(shù)Hanoi塔問(wèn)題設(shè)a,b,c是3個(gè)塔座。開(kāi)始時(shí),在塔座a上一疊共n個(gè)圓盤,這些圓盤自下而上,由大到小地疊在一起。各圓盤從小到大編號(hào)為1,2,...,n2024/12/29392.3遞歸技術(shù)現(xiàn)在要求將塔座a上的這些圓盤移到b上,并仍按有序位置疊置。在移到圓盤時(shí)應(yīng)該遵守以下規(guī)則:每次只能移動(dòng)一個(gè)圓盤;任何時(shí)刻都不允許將大盤壓在小盤上;在滿足規(guī)則1和規(guī)則2的前提下,可將圓盤移至a,b,c中任何一個(gè)塔座上。2024/12/29402.3遞歸技術(shù)這人問(wèn)題有一個(gè)簡(jiǎn)單的解法。假設(shè)塔座a,b,c排成一個(gè)三角形,a->b->c->a構(gòu)成順時(shí)針循環(huán)。在移動(dòng)圓盤的過(guò)程中,若是奇數(shù)次移動(dòng),則將最小的圓盤移到順時(shí)針?lè)降南乱凰?;若是偶?shù)次移動(dòng),則保持最小的圓盤不動(dòng)。而在其他兩個(gè)塔座這間較小的圓盤移到另一塔座上去。2024/12/29412.3遞歸技術(shù)當(dāng)n=1時(shí),問(wèn)題比較簡(jiǎn)單,只要將編號(hào)為1的圓盤從塔座a直接移至b上即可。當(dāng)n>1時(shí),需要利用塔座c作為輔助塔座。此時(shí)若能設(shè)法將n-1個(gè)較小的圓盤按規(guī)則從塔座a移至塔座c,然后將剩下的最大圓盤從塔座a移至塔座b,最后再設(shè)法將n-1個(gè)較小的圓盤按規(guī)則從塔座c移至塔座b。由此可見(jiàn),n個(gè)圓盤的移動(dòng)問(wèn)題可以分為兩次n-1個(gè)圓盤的移動(dòng)問(wèn)題。2024/12/29422.3遞歸技術(shù)可以設(shè)計(jì)出解Hanoi塔問(wèn)題的遞歸算法如下:voidHanoi(intn,inta,intb,intc){ if(n>0) { Hanoi(n-1,a,c,b); move(a,b); Hanoi(n-1,c,b,a); }}2024/12/29432.3遞歸技術(shù)二叉樹(shù)中序遍歷遞歸算法VoidMidOrder(root){ if(root!=null) { MidOrder(root->lchild); treat(root); MidOrder(root->rchild); }}2024/12/29442.3遞歸技術(shù)算法Hanoi以遞歸形式給出,每個(gè)圓盤的具體移動(dòng)方式不清楚,因此很難用手工移動(dòng)來(lái)模擬這個(gè)算法。但該算法易于理解,也容易證明其正確性,而且易于掌握它的設(shè)計(jì)思想。由昆可見(jiàn),用遞歸技術(shù)來(lái)設(shè)計(jì)算法很方便,而且設(shè)計(jì)出的算法往往比通常的算法有效。2024/12/29452.3遞歸技術(shù)2.3.3遞歸過(guò)程的實(shí)現(xiàn)像Hanoi這們的遞歸算法,在執(zhí)行時(shí)需要多次調(diào)用自身。實(shí)現(xiàn)這種遞歸調(diào)用的關(guān)鍵是為算法建立遞歸調(diào)用工作棧。2024/12/29462.3遞歸技術(shù)通常,在一個(gè)算法中調(diào)用另一個(gè)算法時(shí),系統(tǒng)需要在運(yùn)行被調(diào)用算法之前先完成3件事:將所有實(shí)參指針,返回地址等信息傳遞給被調(diào)用算法;為被調(diào)用算法的局部變量分配存儲(chǔ)區(qū);將控制轉(zhuǎn)移到被調(diào)用算法的入口2024/12/29472.3遞歸技術(shù)在從被調(diào)用算法返回調(diào)用算法時(shí),系統(tǒng)也相應(yīng)地完成3件事:保存被調(diào)用算法的計(jì)算結(jié)果;釋放根本給被調(diào)用算法的數(shù)據(jù)區(qū);依照被調(diào)用算法保存的返回地址將控制轉(zhuǎn)移到調(diào)用算法。2024/12/29482.3遞歸技術(shù)當(dāng)有多個(gè)算法構(gòu)成嵌套調(diào)用時(shí),按照后調(diào)用先返回的原則進(jìn)行。遞歸算法之間的信息傳遞和控制轉(zhuǎn)移必須通過(guò)棧來(lái)實(shí)現(xiàn),即系統(tǒng)閨怨整個(gè)程序運(yùn)行時(shí)所需要的數(shù)據(jù)空間安排在一個(gè)棧中,每調(diào)用一個(gè)算法,就為它在棧頂分配一個(gè)存儲(chǔ)區(qū),每退出一個(gè)算法,就釋放它在棧頂?shù)拇鎯?chǔ)區(qū)。當(dāng)前正在運(yùn)行的算法的數(shù)據(jù)一定在棧頂。2024/12/29492.3遞歸技術(shù)2024/12/29502.4解遞歸方程對(duì)于k階齊次方程

F(n)=a1F(n-1)+a2F(n-2)+…+akF(n-k),已知:F(0),F(1),…,F(k-1)共k個(gè)初值特征方程為:

xk-a1xk-1-a2xk-2-…-ak-1x–ak=0;有k個(gè)根q1,…,qk2024/12/29512.4解遞歸方程qi(i=1…k)互不相同,通解如下:

F(n)=C1q1n+C2q2n+…+Ckqkn若有重根q1≠q2≠…≠qi=…=qi+r-1≠qi+r≠…≠qk

,通解為:

F(n)=C1q1n+C2q2n+…+ Ci-1qi-1n+(Ci+Ci+1n+…+Ci+r-1nr-1)qin

+Ci+rqi+rn+…+Ckqkn2024/12/29522.4解遞歸方程對(duì)于k階非齊次方程

F(n)=a1F(n-1)+a2F(n-2)+… +akF(n-k)+f(n)通解為:F(n)=F,(n)+F*(n)。其中F’(n)為無(wú)f(n)時(shí)的通解,即k階齊次方程的通解,F(xiàn)*(n)為特解

2024/12/29532.4解遞歸方程先寫出特征方程然后根據(jù)k個(gè)初值求出待定參數(shù)Ci最后驗(yàn)證2024/12/29542.4解遞歸方程練習(xí)1F(n)=7F(n-1)–12F(n-2);F(0)=4,F(1)=0解:特征方程為x2-7x+12=0; 解得:x1=3,x2=4;F(n)=C13n+C24n ∵F(0)=4,F(1)=0

∴C1=16,C2=-12

∴F(n)=16×3n-12×4n2024/12/29552.4解遞歸方程練習(xí)2F(n)=6F(n-1)–9F(n-2)+3 F(0)=0,F(1)=1解:特征方程為x2-6x+9=0; 解得:x1=x2=3;F(n)=(C1+nC2)3n+C3×3

∵F(0)=0,F(1)=1,F(2)=6,F(1)-9F(0)+3=9

∴C1=-3/4,C2=5/6,C3=1/4

∴F(n)=-3/4×3n+5/6×3n+3/42024/12/29562.4解遞歸方程練習(xí)3F(n)=7F(n-1)–10F(n-2)+3n F(0)=0,F(1)=1解:特征方程為x2-7x+10=0; 解得:x1=2,x2=5;

F(n)=C12n+C25n+C33n ∵F(0)=0,F(1)=1,F(2)=7F(1)-10F(0)+32=16

∴C1=8/3,C2=11/6,C3=-9/2

∴F(n)=8/3×2n+11/6×5n-9/2×3n2024/12/2957第三章分治與平衡

楊素勤(1200600985)2024/12/2958分治與平衡的思想把一個(gè)問(wèn)題分成k個(gè)同類子問(wèn)題處理的分治思想和子問(wèn)題規(guī)模大體相等的平衡思想(balancing)相結(jié)合,即為分治與平衡算法.2024/12/2959兩個(gè)非遞減序列的合并下面將介紹兩個(gè)有序非遞減序列如何合并為一個(gè)有序序列:給定兩個(gè)非遞減有序數(shù)列和把這兩個(gè)序列按非遞減有序合并入。分別取出兩個(gè)序列中的第一個(gè)元素,對(duì)這兩個(gè)元素進(jìn)行比較。如果a1不大于b1,則將a1存入c1,取出a2與b1進(jìn)行比較。如果a1大于b1則將b1存入c1取出b2與a1進(jìn)行比較。重復(fù)上述步驟,直到兩個(gè)序列完全合并。2024/12/2960兩個(gè)非遞減序列合并的算法將:和合并存入ProcedureMERGEI

i=1;j=1;k=1;While(i<=m)and(j<=n)doIfA[i]<=B[j]thenbeginC[k]=A[i];i=i+1;k=k+1;end;2024/12/2961兩個(gè)非遞減序列合并的算法elseC[k]=B[j];j=j+1;k=k+1;end;ifi>mthen{將bj、bj+1、…、bn

依次賦值給Ck}Else{將ai、ai+1、…、am依次賦值給Ck}算法中,最大的比較次數(shù)為m+n-1.2024/12/2962合并排序思想設(shè)給定集合S={x1,x2,……,xn},且n=2k。當(dāng)n>2時(shí),把S分成兩個(gè)不相交的子集合S1={x1,x2,……xn/2}和集合S2={xn/2+1,xn/2+2,……,xn}。直到集合S分解到每個(gè)子集合的元素不超過(guò)2時(shí)為止。比較1次即可將只有兩個(gè)元素的子集排序.調(diào)用前面的MERGEI算法將各個(gè)子集合合并。2024/12/2963合并排序算法procedureMERGESORTinteger:n;array:A[1:n]ofinteger;procedureSORT(A,i,j);integer:i,j,m;array:A[i:j]ofinteger;beginifj-i=1thenifA[i]>A[j] 2024/12/2964合并排序算法elsebeginm=(i+j-1)/2; SORT(A,i,m); SORT(A,m+1,j); MERGEI(A[i:m],A[m+1:j]) end;end;begin read(n,A); SORT(A,1,n); write(A);end2024/12/2965用二叉樹(shù)來(lái)表示排序a>=bb>=ca>=ca>=cb>=ca,b,ca,c,bc,a,bb,c,ac,b,ab,a,cYNYNYNYNYN2024/12/2966用二叉樹(shù)來(lái)表示排序左圖為一棵平衡二叉樹(shù),平均比較次數(shù)(時(shí)間復(fù)雜度)為(2×2+3×4)÷6=2.67。原始數(shù)據(jù)的狀態(tài)會(huì)影響排序的效率。2024/12/2967用二叉樹(shù)來(lái)表示排序N個(gè)數(shù)排序,有n!種結(jié)果,對(duì)應(yīng)的二叉樹(shù)有n!片樹(shù)葉。如果算法對(duì)應(yīng)一棵平衡二叉樹(shù)一定存在一個(gè)k使K對(duì)應(yīng)平衡二叉樹(shù)中深度小的結(jié)點(diǎn),而k+1則對(duì)應(yīng)二叉樹(shù)中深度大的結(jié)點(diǎn)。若,任何需要比較進(jìn)行的排序算法,已經(jīng)是最好的算法數(shù)量級(jí)。2024/12/2968快速排序?qū)⒓蟂={a1,a2,……,an}分成小于a,等于a,大于a的三個(gè)子集合S1,S2,S3。分別將S1與S3排序,最后將S1,S2和S3連接起來(lái)。 優(yōu)點(diǎn):(1)劃分以后就減少了待排序元素的數(shù)量。 (2)子集合排序后采用連接而不用比較就可以歸并。 缺點(diǎn):a難以確定恰當(dāng)?shù)卮_定,因此平衡的思想就難以體現(xiàn)。

2024/12/2969快速排序算法先要解決如何在同一數(shù)組中劃分子集合:a1,a2,a3,……,an-1,anwhilei<jdobeginwhileai<adoi=i+1;whileaj<adoj=j-1;

交換ai和ajend;2024/12/2970快速排序算法procedureQUICKSORT(S); if||S||<=2then begin

將S中的元素直接排序;

return(S) end else begin

從集合S中隨機(jī)選取一個(gè)元素a; 把S中的元素分成小于a,等于a和大于a三個(gè)子集合S1,S2,S3; return(QUICKSORT(S1)接著S2接著QUICKSORT(S3)) end2024/12/2971課后作業(yè)考慮分治—合并排序算法,重新設(shè)計(jì)MERGEI(A,B),考慮n不一定等于實(shí)現(xiàn)快速排序算法。第四章排序2024/12/2973目錄4.1排序的定義4.2基數(shù)排序4.3比較排序的時(shí)間下界4.4堆選排序4.5插入法2024/12/29

2024/12/29744.1排序的定義半序的定義

定義如果集合S上的一個(gè)關(guān)系R,對(duì)于S中的任何元素a,b,c,若

1.aRa為真(自反性);

2.由aRb和bRc可得aRc(傳遞性);

3.由aRb和bRa可得a=b

(反對(duì)稱性);則稱R為集合S上的一個(gè)半序(partiaorder)。2024/12/29

2024/12/29754.1排序的定義排序的定義

給定一個(gè)從有線性序R的集合中抽出來(lái)的n個(gè)元素a1,a2,…,an。所謂將這n個(gè)元素排序就是要找出1,2,…,n的一個(gè)特定排列

∏(1),∏(2)

,…,∏(n),使得對(duì)于任何i,

1≤i<n,有a∏(i)Ra∏(i+1)。當(dāng)關(guān)系R是“≤”時(shí),既有

a∏(i)≤

a∏(i+1)≤…≤a∏(n)。2024/12/29

2024/12/29764.2基數(shù)排序待排序元素a1,a2,…,an,將其置于一個(gè)桶(隊(duì)列)Q中。ak均為k元組,每一元由m個(gè)不同的符號(hào)而組成,另設(shè)m個(gè)不同的桶分別對(duì)應(yīng)m個(gè)符號(hào)。將Q中元素按元分裝到m個(gè)桶中,再將m個(gè)桶中的元素歸并到Q中,如此進(jìn)行k次,即可使Q中的元素有序。2024/12/29

2024/12/29774.2基數(shù)排序例用桶排序法將以下6個(gè)數(shù)排序:

379,258,731,432,913,455

0號(hào)桶1號(hào)桶2號(hào)桶3號(hào)桶4號(hào)桶5號(hào)桶6號(hào)桶7號(hào)桶8號(hào)桶9號(hào)桶按各位數(shù)置桶731432913455258379第一次合并后隊(duì)列731432913455258379按十位數(shù)置桶913731432455258379第二次合并后隊(duì)列913731432455258379按百位數(shù)置桶258379432455731913結(jié)果2583794324557319132024/12/29

2024/12/29784.2基數(shù)排序算法4.1桶排序法

輸入一個(gè)序列A1,A2,…,An;這里每個(gè)元素Ai是一個(gè)K元組(ai1ai2…aik),其中,對(duì)一切i,,j;1≤i≤n,

1≤j≤k,有0≤aij≤m-1。輸出序列A∏(1)≤

A∏(2)≤

≤A∏(n),它是A1,A2,…,An的一個(gè)排列。方法使用隊(duì)列QUEUE存放“當(dāng)前的元素序列”,還有m個(gè)桶Q[0],Q[1],…,Q[m-1],它們都是一個(gè)先進(jìn)先出的對(duì)列。用Q[i]來(lái)存放當(dāng)前的分量是正數(shù)i的那些元素。(參見(jiàn)過(guò)程BUCKETSORT)。2024/12/29

2024/12/29794.2基數(shù)排序基數(shù)排序算法(算法4.1)

procedureBUCKETSORTbegin

置A1,A2,…,An到隊(duì)列QUEUE中;

fori←jstep-1until1dobeginforI←0tom-1do置Q[I]為空;

whileQUEUE非空do把QUEUE中的第一個(gè)元素Ai置入桶Q[aij]中;

forl←0tom-1do依次置Q[l]中的元素到QUEUE中

endend定理4.1

算法BUCKETSORT將n個(gè)元素排序所需的時(shí)間是O(k(m+n)),其中k是每個(gè)元素的長(zhǎng)度,每個(gè)分量是介于0到m-1之間的整數(shù)。2024/12/29

2024/12/2980問(wèn)題能否用基數(shù)排序法對(duì)不超過(guò)k元的多元組進(jìn)行排序?若回答肯定,對(duì)元組分別為多數(shù)字和字符串時(shí)如何處理?2024/12/29814.3比較排序的時(shí)間下界引理4.1

一棵高為h的二叉樹(shù),最多有2h個(gè)葉。定理4.3

將n個(gè)不同元素排序的任一判定樹(shù)的高不小于「log2n!」。2024/12/29

2024/12/29824.4堆選排序堆選排序堆是一棵完全二叉樹(shù)且

ai>=a2i,ai>=a2i+1

把所有要排序的元素建成一個(gè)堆,然后刪去根節(jié)點(diǎn)上的元素。將最大深度的最右邊的葉元素移至根結(jié)點(diǎn),將這棵樹(shù)再建成一個(gè)堆。重復(fù)上述過(guò)程,直到這棵樹(shù)只剩一個(gè)頂點(diǎn)為止。從這個(gè)堆的根節(jié)點(diǎn)上刪去的元素序列(按刪去的先后順序排列起來(lái))就是一個(gè)排序好的非遞增序列2024/12/29

2024/12/29834.4堆選排序堆排序的過(guò)程是,把初始數(shù)據(jù)“堆化”后,重復(fù)執(zhí)行如下兩個(gè)步驟:1.刪除根節(jié)點(diǎn)的元素;2.將最深最右的葉元素移到根節(jié)點(diǎn)并刪去這個(gè)葉,重新堆化。在實(shí)際處理時(shí),只需將根節(jié)點(diǎn)元素和待刪葉元素互換,就能達(dá)到刪除根節(jié)點(diǎn)元素和把最深最右的葉元素移至根節(jié)點(diǎn)上的雙重目的,然后對(duì)剩下的元素重新堆化。例對(duì)50,24,30,20,21,18,3,12,5,6進(jìn)行堆排序。2024/12/29

2024/12/29844.4堆選排序例對(duì)50,24,30,20,21,18,3,12,5,6進(jìn)行堆排序。下列的圖表示刪去根元素和重新堆化的過(guò)程。50242012530211836(i)624201253021183(ii)刪去50,將6移至根部2024/12/29

2024/12/29854.4堆選排序如果用數(shù)組記錄上述過(guò)程,數(shù)組元素的變化如下:(i)50,24,30,20,21,18,3,12,5,6(ii)6,24,30,20,21,18,3,12,5,50(iii)30,24,6,20,21,18,3,12,5,50(iv)6,24,18,20,21,6,3,12,5,50302420125621183(iii)將6與它的最大兒子30交換302420125182163(iv)將6與它的最大兒子18交換2024/12/29

2024/12/29864.4堆選排序算法4.3構(gòu)造一個(gè)堆輸入數(shù)組A[i],1≤i≤n。輸出把A的元素變成一個(gè)堆,即使得對(duì)于1<i≤n,

A[i]≤A[「i/2

」]。方法見(jiàn)過(guò)程BUILDHEAP。2024/12/29

2024/12/29874.4堆選排序構(gòu)造一個(gè)堆(算法4.3)

procedureBUILDHEAPbeginprocedureHEAPIFY(i,j)beginif2i<jthenifA[2i]≤A[2i+1]且A[i]≤A[2i+1]thenbegin

交換A[i]和A[2i+1];

HEAPIFY(2i+1,j);endif2i=jthenifA[i]<A[j]then交換A[i]和A[j]endbeginread(A[1],A[2],…,A[n]);fori←「n/2」step-1until1doHEAPIFY(i,n)end2024/12/29

2024/12/29884.4堆選排序算法4.4

堆選排序算法。輸入數(shù)組A[1:n]。輸出按非遞減序排列的結(jié)果。方法見(jiàn)過(guò)程HEAPSORT

procedureHEAPSORT:beginBUILDHEAP;fori←nstep-1until2dobegin

交換A[1]和A[i];

HEAPIFY(1,i-1);endend

2024/12/29

2024/12/29894.4堆選排序定理4.5

算法HEAPSORT對(duì)n個(gè)元素排序所需的時(shí)間是O(nlog2n)。2024/12/29

2024/12/29904.5插入法分段逆序插入法

設(shè)A={a1,a2,…,am}是一個(gè)非遞減序列。B={b1,b2,…,bm+∈}是序列A的伴隨序列,即對(duì)一切1≤i≤m,有bi≤ai,其中∈的值是0或1。將B中的元素插入到序列A中,使A、B合并為一個(gè)大的非遞減的序列。因?yàn)橐阎猙i≤ai,所以對(duì)任何bi,只要能把它插入到a1,a2,…,ai-1的合適位置即可。如果在bi插入前,已有某個(gè)bj(j≠i)

已插入到a1,a2,…,ai-1中,bi同樣可以插入到ai左部的部分序列中。2024/12/29

2024/12/29914.5插入法bi插入的方法就是所謂的分段逆序插入法。對(duì)較小的m,序列B中元素的插入順序和所需比較的次數(shù)見(jiàn)下表。Aa1a2a3a4a5a6a7a8a9a10a11a12a13…a21a22a23…a43a44…Bb1b2b3b4b5b6b7b8b9b10b11b12b13…b21b22b23…b43b44…bi插入順序13254111098762120…124342…2285…最大的比較次數(shù)0223344444455…566…67…Bi插入的順序和所需的比較次數(shù)2024/12/29

2024/12/29924.5插入法bi的插入順序和所需比較次數(shù)是這樣得到的。因?yàn)閎1≤a1,直接把b1置于a1的前面。當(dāng)m+∈≥3時(shí),先將b3按折半查找插入序列b1a1a2中,需要兩次比較。插入的結(jié)果,即使b3小于a2,再插入b2時(shí),也不過(guò)是將它插入b1a1和b3構(gòu)成的長(zhǎng)度為三的序列中,仍然只要兩次比較。至此,a4以前一共有6個(gè)元素。如果m+∈≥則先插b5,后查b4,它們最多時(shí)插入一個(gè)7元序列中,各需三次比較等等。為嚴(yán)格描述分段逆序折半插序,定義了一個(gè)遞歸函數(shù)f(n)

(稱做分段函數(shù))。它是f(n)=1,當(dāng)n=1時(shí)2n+f(n-1),當(dāng)n=1時(shí)2024/12/29

2024/12/29934.5插入法算法4.5

分段逆序插入法

輸入非遞減序列A=={a1,a2,…,am}和它的伴隨序列B={b1,b2,…,bm+∈},對(duì)一切1≤i≤m,有bi≤ai,其中∈的值是0或1。輸出由A和B的全體元素組成的一個(gè)非遞減序列。方法見(jiàn)過(guò)程BYFINSERT

procedureBYFINSERT(‖B‖,A,B)begin

將b1插到a1的前面;找到一個(gè)整數(shù)k≥2,使得f(k-1)<m+∈≤f(k);

按b3,b2;b5,b4;…;bf(k-2),bf(k-1)-1,…,bf(k-2)+1;bm+∈,…,bf(k-1)+1的順序?qū)i折半插入序列A中。

end2024/12/29

2024/12/29944.5插入法插入排序法

把要排序的n個(gè)元素,分成兩個(gè)一對(duì)分別比較,把各對(duì)中較大的元素記入子序列S1中,較小的序列記入子序列S2中,即S1和S2中的元素有一對(duì)一的大小關(guān)系。當(dāng)n為奇數(shù)時(shí),S中的第n個(gè)元素記入S2的末尾。然后,將S1中的元素排序(遞歸的應(yīng)用插入法)。最后,使用分段逆序插入法把S2中的元素插入已排序的S1中,就得到n個(gè)元素的有序序列(當(dāng)元素個(gè)數(shù)較少時(shí)(n≤4),就直接排序)。2024/12/29

2024/12/29954.5插入法例用排序法將以下11個(gè)元素排序,它們是

11,127,43,574,5,560,700,708,9,20,31第一步:11~127,43~574,5~560,700~708,9~20,31,得

S1={127,574,560,708,20}S2={11,43,5,700,9,31}第二步:將S1的元素排序。因?yàn)椤琒1‖=5>4,做127~574,560~708,得

S1′={574,708}S2′={127,560,20}

對(duì)S1′排序。因?yàn)椤琒1′‖=2<4,用“”比較“直接排序,得排序的S1′為574,7082024/12/29

2024/12/29964.5插入法

由S1′和S2′的關(guān)系,有

574<708

↓↓12756020

按分段逆序插入法,用兩次比較(20~574,20~127)先將20插入序列

127<574<708

之中,然后將560插入序列

20<127<574<708

之中,也只需兩次比較(560~127,560~574),得到S1的排序結(jié)果為

20<127<560<574<7082024/12/29

2024/12/29974.5插入法第三步:用逆序插入法將S2插入S1。根據(jù)S1和S2的元素對(duì)應(yīng)關(guān)系,有

20<127<560<574<708

↓↓↓↓↓91154370031按分段逆序插入法,插入順序依次是5,11,700,43,31。各插入結(jié)果是:

5<9<20<127<560<574<708

↓↓↓1143700312024/12/29

2024/12/29984.5插入法

5<9<11<20<127<560<574<708

↓↓4370031

5<9<11<20<127<560<574<700<708

↓43315<9<11<20<43<127<560<574<700<708315<9<11<20<31<43<127<560<574<700<708累計(jì)總的比較次數(shù),最多要26次。2024/12/29

2024/12/29994.5插入法算法4.6

插入排序輸入數(shù)組A=={a1,a2,…,an}

輸出元素a1,a2,…,an的一個(gè)非遞減序列。

方法見(jiàn)過(guò)程INSERT(S1i,i)。在應(yīng)用時(shí),只要執(zhí)行語(yǔ)句調(diào)用INSERT(S10,0)。這里S10=A。

2024/12/29

2024/12/291004.5插入法procedureINSERT(S1i,i)if‖S1i‖≥4thenbegin

把S1i中的元素分成「‖S1i‖/2」對(duì)兩兩比較;各組中的較大元素依次記入S1i+1中;各組中的較小元素依次記入S2i+1中。當(dāng)‖S1i‖為奇數(shù)時(shí),將S1i中最末的一個(gè)元素記入S2i+1的末尾;

INSERT(S1i+1,i+1);return(BYFINSERT(「‖S1i‖/2」,S1i+1,S2i+1)endelsebegin

直接將S1i中的元素排序;

return(S1i)end2024/12/29

2024/12/29101第五章動(dòng)態(tài)規(guī)劃2024/12/29102引言所謂動(dòng)態(tài)規(guī)劃(Dynamicprogramming)常常能得到一個(gè)比窮舉法有效的算法。動(dòng)態(tài)規(guī)劃的指導(dǎo)思想是,在每種情況下,列出各種可能的局部解,然后按某些條件,從局部解(或中間結(jié)果)中挑選出那些有可能產(chǎn)生最佳解的結(jié)果而揚(yáng)棄其余。從而大大縮減了計(jì)算量。動(dòng)態(tài)規(guī)劃遵循所謂“最佳原理”的原則。即“不論前面的狀態(tài)和策略如何,后面的最優(yōu)策略只取決于由最初策略所確定的當(dāng)前狀態(tài)?!奔础白顑?yōu)化從當(dāng)前狀態(tài)開(kāi)始”.2024/12/29103引言動(dòng)態(tài)規(guī)劃所適用的問(wèn)題:1)優(yōu)化問(wèn)題2)分階段處理的問(wèn)題3)狀態(tài)之間有確定次序的問(wèn)題。不能跨越2024/12/291045.1單源最短路徑問(wèn)題1.多級(jí)圖

G={V,E}其中V是頂點(diǎn)的集合,E是邊(弧)的集合

Vi也是頂點(diǎn)的集合,Ei是邊的集合,如果

V=∪Vi∩iVi為空當(dāng)(vl,vt)屬于Ei且vl屬于Vi時(shí),必有Vt屬于Vi+1,則G為多級(jí)圖2024/12/291055.1單源最短路徑問(wèn)題最短路徑:是按道路上的代價(jià)函數(shù)來(lái)判定的。如果是兩個(gè)城市,道路上的代價(jià)函數(shù)可能是城市間的里程,或者旅差費(fèi)用等。2024/12/291065.1單源最短路徑問(wèn)題COST(i,j)第i級(jí)頂點(diǎn)vj到匯點(diǎn)的最短路徑長(zhǎng)度C(i,j)邊(vi,vj)上的權(quán)值COST(i,j)=min{c(j,l)+COST(i+1,l)},其中l(wèi)屬于頂點(diǎn)集Vi+12024/12/291075.1單源最短路徑問(wèn)題2024/12/291085.1單源最短路徑問(wèn)題對(duì)于圖5.1,計(jì)算過(guò)程如下:COST(3,6)=min{6+COST(4,9),5+COST(4,10)}=min{6+4,5+2}=7COST(3,7)=min{4+COST(4,9),3+COST(4,10)}=min{4+4,3+2}=5COST(3,8)=72024/12/291095.1單源最短路徑問(wèn)題COST(2,2)=min{4+COST(3,6),2+COST(3,7),1+COST(3,8)}=min{11,7,8}=7COST(2,3)=9COST(2,4)=11+COST(3,8)=18COST(2,5)=15COST(1,1)=min{9+COST(2,2),7+COST(2,3),3+COST(2,4),2+COST(2,5)}=min{16,16,21,17}=162024/12/291105.1單源最短路徑問(wèn)題因此,從S到T的一條最短路徑的代價(jià)是16。只要我們每次記下使COST(i,j)達(dá)到最小的第j+1級(jí)的頂點(diǎn)號(hào),這條路徑也就找到了。2024/12/291115.1單源最短路徑問(wèn)題算法:兩點(diǎn)間的最短路算法(由后向前)_用cost(j)代替cost(i,j),即不記錄頂點(diǎn)所在級(jí),存儲(chǔ)多級(jí)圖時(shí)應(yīng)如何處理?____________________________________PROCEDUREFGRAPHBeginFori←1tondoCOST[i]←0;Forj←n-1to1do//計(jì)算COST[j]//2024/12/291125.1單源最短路徑問(wèn)題Begin設(shè)L是這樣一個(gè)頂點(diǎn),邊(j,L)屬于E且c(j,L)+COST[L]最?。籆OST[j]←c(j,L)+COST[L];D[j]←L;End2024/12/291135.1單源最短路徑問(wèn)題//找最小代價(jià)的道路//P[1]←1,P[k]←n;Forj←2tok-1doP[j]←D[P[j-1]]End________________________________2024/12/29114第六章貪心法任何問(wèn)題,通常都有n個(gè)輸入和一些約束條件。任何滿足這些約束條件的子集可稱為一個(gè)可能解。最佳解是滿足目標(biāo)函數(shù)達(dá)到最大值或最小值的一個(gè)可能解,而目標(biāo)函數(shù)是問(wèn)題中給定的。貪心法是一個(gè)多步?jīng)Q策法,每一步的選擇都使得能構(gòu)成問(wèn)題的一個(gè)可能解(即滿足問(wèn)題的全部約束條件),同時(shí)使目標(biāo)函數(shù)的值增加最快或增加最小。貪心法的選擇過(guò)程是以某些最優(yōu)化量度為根據(jù),而最優(yōu)化量度有時(shí)可以是目標(biāo)函數(shù)本身,有時(shí)也可能是別的量度。最優(yōu)化量度的選擇是貪心法的關(guān)鍵。2024/12/291156.1背包問(wèn)題背包問(wèn)題的來(lái)源:設(shè)某港口有n種不同的貨物送往某地,每種貨物的總重量是已知的,各種不同貨物的運(yùn)價(jià)也是確定的。某支船隊(duì)承運(yùn)部分貨物,船隊(duì)的總噸位是確定的。每種貨物允許分批發(fā)送??紤]這支船隊(duì)?wèi)?yīng)裝運(yùn)哪些貨物才能使它一次獲得的運(yùn)費(fèi)最多?2024/12/291166.1背包問(wèn)題背包問(wèn)題的一般描述:給定n種不同的物品和一個(gè)背包。物品i的重量是Wi,背包容量為M。假定物品i的一部分xi(0≤xi≤1),被放進(jìn)背包里,就會(huì)得到利潤(rùn)

Pixi。因?yàn)楸嘲娜萘繛镸,要求被裝進(jìn)的物品的總重量不超過(guò)M(若只考慮物重而不考慮其形狀和體積)。問(wèn)應(yīng)怎樣選擇物品的種類和數(shù)量,使背包裝滿,而獲得最大的利潤(rùn)。2024/12/291176.1背包問(wèn)題背包類問(wèn)題還可形式化描述為:給定M>0,Wi>0,Pi>0,1≤i≤n,使之滿足:使:達(dá)到最大。滿足0≤xi≤1的任何向量(x1,x2,…xn)都是一個(gè)可能解。這樣的解顯然有無(wú)窮多個(gè)。而最佳解必需是使式(6.2)的值達(dá)到最大的一個(gè)可能解。(6.1)(6.2)2024/12/291186.1背包問(wèn)題例:給定n=3,M=40,(W1,W2,W3)=(28,15,24),(p1,p2,p3)=(35,25,24)。以下是此例的五個(gè)可能解:

(x1,x2,x3)∑Wixi∑pixi(1)(1,4/5,0)4055(2)(1/2,1,1/3)3750.5(3)(1/28,1,1)4050.25(4)(5/7,1,5/24)4055(5)(25/28,1,0)4056.252024/12/291196.1背包問(wèn)題對(duì)于這個(gè)簡(jiǎn)單的實(shí)例,因?yàn)樗目赡芙庥袩o(wú)窮多個(gè),所以用組合的方法求最佳解是行不通的??紤],如果成立,最佳解將取xi=1。因此,不妨假定成立。這就不可能取一切xi=1。在此前提下,任何最佳解都必須將背包裝滿。同時(shí),由于pi>0,使利潤(rùn)增加。這樣得到的解比原來(lái)的解要好。2024/12/291206.1背包問(wèn)題人們可能會(huì)想到的貪心的策略:(1)按pi遞減順序裝包(效益增長(zhǎng)最快)每次選擇利潤(rùn)Pi最大的物品裝包,使得目標(biāo)函數(shù)增加最快。當(dāng)放不下時(shí),才選擇一個(gè)適當(dāng)?shù)膞i<1,使物品裝滿,可求出每一種貨物裝入背包的比例X(x1,x2,x3)x1=1,CU=M-28=40-28=12,

x2=CU/W2=12/15=4/5,CU=0,

x3=0

所以,X=(1,4/5,0),2024/12/291216.1背包問(wèn)題(2)按Wi非遞減順序裝包(背包容量消耗最慢)

x2=1,CU=M-15=40-15=25,

x3=1,CU=25-24=1x1=1/28

所以,X=(1/28,1,1)。(3)按Pi/Wi(單位重量效益)遞減順序裝包每次選擇利潤(rùn)與重量比最大的物品先裝包。先算出每種貨物的單位重量效益:(35/28,25/15,24/24)x2=1,CU=25x1=25/28

2024/12/291226.1背包問(wèn)題總結(jié):由上面的結(jié)果可看出,策略(1)顯然不是最佳解,因?yàn)檫@種選擇方法雖然每一步都使目標(biāo)函數(shù)得到最大的增量,但由于背包也很快背裝滿了,加入目標(biāo)函數(shù)的Pi的個(gè)數(shù)少了,不一定能使目標(biāo)函數(shù)達(dá)到最大。策略(2)也不是最佳解,雖然背包的重量上升很慢,卻沒(méi)有兼顧利潤(rùn)的增長(zhǎng)速度,不能保證得到最佳解。策略(3)考慮到利潤(rùn)增長(zhǎng)和容量消耗二者的綜合效果,因此可以得到一個(gè)相對(duì)的最佳解。

2024/12/29123背包問(wèn)題的貪心算法:Input:P(1,2…n),W(1,2…n),MOutput:x1,x2…xnVoidGreedy(){ floatP[],W[],X[],M,CU;inti,n;

輸入P[1,2…n],W[1,2…n],M;//按p[i]/w[i]從大到小的順序輸入

for(i=1;i<=n;i++){x[i]=0;}CU=M//CU是背包的剩余容量

intI=1;

while(W[I]<=CU){//背包未滿

x[I]=1;CU=CU-W[I];I=I+1;}x[I]=CU/W[I];}2024/12/291246.2多處理機(jī)調(diào)度設(shè)有n臺(tái)相同的處理機(jī)P1,P2,…,Pn,處理m個(gè)獨(dú)立的作業(yè)J1,J2,…,Jm,以互不相關(guān)的工作方式工作。規(guī)定:任何作業(yè)可以在任何一臺(tái)處理機(jī)上運(yùn)行,但未完工前不允許中斷作業(yè);作業(yè)也不能折分成更小的子作業(yè)。多處理機(jī)調(diào)度:已知作業(yè)Ji需要的處理機(jī)時(shí)間為ti,i=1,2,…,m。我們的任務(wù)是給出一種作業(yè)調(diào)度方案,使m個(gè)作業(yè)在盡可能短的時(shí)間內(nèi),由n臺(tái)處理機(jī)完成。2024/12/291256.2多處理機(jī)調(diào)度例:設(shè)有三臺(tái)處理機(jī)和九個(gè)作業(yè),這些作業(yè)需要的運(yùn)行時(shí)間分別是81,40,26,4,65,98,53,71,15。按上述調(diào)度法則,各處理機(jī)分配的作業(yè)表將如下圖所示??偼旯r(shí)間是166。

P1P2P3J181J753J44J240J698J871J326J565J915(a)一種簡(jiǎn)單的多處理機(jī)調(diào)度方案2024/12/291266.2多處理機(jī)調(diào)度P1P2P3J698J240J44J181J753J326J271J565J915(a)先長(zhǎng)后短調(diào)度方案(a)是按作業(yè)花費(fèi)時(shí)間的長(zhǎng)短進(jìn)行調(diào)度的,把需時(shí)較長(zhǎng)的作業(yè)優(yōu)先安排,先將作業(yè)按運(yùn)行時(shí)間的長(zhǎng)短從大到小排成非遞增序,然后給空閑的處理機(jī)依次分配作業(yè)??偼旯r(shí)間是160。2024/12/291276.2多處理機(jī)調(diào)度P1P2P3J698J753J181J240J326J44J871J565J915(b)最佳調(diào)度方案(b)是本例的一個(gè)最佳調(diào)度方案。它們的完工時(shí)間是151。由此可見(jiàn)貪心算法得到的不一定是最佳方案。2024/12/29128第七章回溯法問(wèn)題描述算法思想狀態(tài)空間樹(shù)皇后問(wèn)題算法復(fù)雜度分析2024/12/291297.1問(wèn)題分析求一個(gè)n元向量(x1,x2,……,xn),使之滿足對(duì)問(wèn)題的某個(gè)判定函數(shù)B(x1,x2,……,xn

)規(guī)定的條件。若Xi∈i,||Si||=Mi,則所有可能的選擇有mi種,對(duì)Xi的取值有明確要求,稱為顯約束。判斷函數(shù)規(guī)定的約束成為隱約束。2024/12/291307.2算法思想

從部分分量(x1,x2,…,xi)出發(fā)(i=1,2,…,n-1),選擇xi+1,如果(x1,x2,…,xi+1)滿足判定函數(shù)規(guī)定的條件,且i+1=n,則得到一個(gè)解;若(x1,x2,…,xi+1)滿足判定函數(shù),但i+1<n,繼續(xù)選擇xi+2,若(x1,x2,…,xi)不滿足判定函數(shù),則另選xi+1,如果可供選擇的xi+1均不滿足判定條件,則重新選擇xi(回溯).2024/12/291317.2算法思想注意:判定函數(shù)的設(shè)計(jì)應(yīng)使其部分向量可計(jì)算!2024/12/291327.3狀態(tài)空間樹(shù)為了我們敘述的方便,我們?cè)谶@里先介紹一些相關(guān)的概念,回溯法是采用體統(tǒng)地搜索給定問(wèn)題的解空間的方法來(lái)確定問(wèn)題的解。使用一種所謂解空間的樹(shù)形結(jié)構(gòu)將使這種搜索容易實(shí)現(xiàn)。對(duì)于一個(gè)解空間,可能有很多樹(shù)形結(jié)構(gòu)與之相對(duì)應(yīng)。相關(guān)的例子請(qǐng)參照課本。我們現(xiàn)在來(lái)定義解空間樹(shù)形結(jié)構(gòu)的一些術(shù)語(yǔ)。2024/12/291337.3狀態(tài)空間樹(shù)樹(shù)上的每一個(gè)節(jié)點(diǎn)定義了一個(gè)“問(wèn)題狀態(tài)”;從根到每個(gè)節(jié)點(diǎn)的所有路徑定義了這一問(wèn)題的“狀態(tài)空間“;“問(wèn)題狀態(tài)”集的子集S組成了問(wèn)題的“解狀態(tài)集”;可以生孩子的節(jié)點(diǎn)成為“活節(jié)點(diǎn)”,存儲(chǔ)活節(jié)點(diǎn)的表成為活節(jié)點(diǎn)表;2024/12/291347.3狀態(tài)空間樹(shù)正在生孩子的節(jié)點(diǎn)稱為擴(kuò)展節(jié)點(diǎn);不能生孩子的節(jié)點(diǎn)稱為死節(jié)點(diǎn)。2024/12/291357.4皇后問(wèn)題介紹完相關(guān)的概念后,我們將介紹一個(gè)關(guān)于回溯法的例子,當(dāng)然,這個(gè)例子具有廣泛的代表性,這就是皇后問(wèn)題。2024/12/291367.4皇后問(wèn)題問(wèn)題:

n個(gè)皇后,置于n*n的方格內(nèi),如果任何兩個(gè)皇后處于同一行,同一列,或處于與邊線成45°角的斜線上,都會(huì)遭到對(duì)方攻擊,求一種互不遭到攻擊的狀態(tài)。2024/12/291377.4皇后問(wèn)題我們規(guī)定第i個(gè)皇后位于第i行,n個(gè)皇后所在的列構(gòu)成一個(gè)n元向量(x1,x2,…,xi),xi∈{1,2,…,n}.2024/12/291387.4皇后問(wèn)題皇后甲(i,j)皇后乙(k,l)

|(i-k)/(j-l)|≠1B=(i-k)/(j-l)2024/12/291397.4皇后問(wèn)題下面我們已四皇后問(wèn)題為例:首先:i=1(放置第1個(gè)皇后)(12024/12/291407.4皇后問(wèn)題i=2

(1,2×(因(1-2)/(1-2)=1)故(1,32024/12/291417.4皇后問(wèn)題i=3(1,3,2×(1,3,4×

我們發(fā)現(xiàn)第三個(gè)皇后已經(jīng)沒(méi)有合適的位置,此時(shí)需要重新放置第(i-1)個(gè)(

溫馨提示

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

最新文檔

評(píng)論

0/150

提交評(píng)論