版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
數(shù)據(jù)結(jié)構(gòu)與C/C++&Java北京工業(yè)大學(xué)計算機學(xué)院軟件學(xué)科部陳文博
2004數(shù)據(jù)結(jié)構(gòu)與算法1第十章算法設(shè)計與分析導(dǎo)論數(shù)據(jù)結(jié)構(gòu)與算法2主要內(nèi)容
算法設(shè)計與分析內(nèi)容介紹算法分析的方法遞歸與分治算法回溯算法貪心算法
數(shù)據(jù)結(jié)構(gòu)與算法3算法設(shè)計與分析內(nèi)容介紹從引例看算法設(shè)計表達(dá)算法的抽象機制數(shù)學(xué)算法與數(shù)據(jù)結(jié)構(gòu)算法算法與數(shù)據(jù)結(jié)構(gòu)的關(guān)系算法分析的方法常用算法模式數(shù)據(jù)結(jié)構(gòu)與算法4010203040506071234四染色地理結(jié)論的實現(xiàn)123456712345670111111100011010011001010100111101111001011000110從引例看算法設(shè)計11數(shù)據(jù)結(jié)構(gòu)與算法5BacktrackingAlgorithmIdea數(shù)據(jù)結(jié)構(gòu)與算法6publicbooleanbacktrack(){
Stack
S=newArrayStack();//Initializesystem;i=1;//the
i
isnumberofatask
j=1;//the
j
isitemnumberofchoice
do{
}(!wholeprojecthascompleted)}//accomplishbacktrack數(shù)據(jù)結(jié)構(gòu)與算法7do{while((!Thechoiceexceedsthescope)&&(!wholeprojecthascompleted)){
if(!matchConstraint(i,j))j++;
elsebreak;}
if(!Thechoiceexceedsthescope){
S.push((i,j));i++;j=1;//newtaskinbeginning}elseif(!S.empty()){(i,j)=S.pop();j++;//testnewchoice}elsereturn
false;
if(wholeprojecthascompleted))return
true;}(!wholeprojecthascompleted)數(shù)據(jù)結(jié)構(gòu)與算法8
ADT
Stack
{
數(shù)據(jù)對象:
D={ai|ai∈ElemSet,i=1,2,...,n,n≥0}
數(shù)據(jù)關(guān)系:
R={<ai-1,ai>|ai-1,ai∈D,i=2,...,n}
約定an
端為棧頂,a1端為棧底。
}ADTStack
基本操作:
Stack()
empty()
push(e)
pop()數(shù)據(jù)結(jié)構(gòu)與算法9表達(dá)算法的抽象機制數(shù)
據(jù)
模
型初始狀態(tài)結(jié)果狀態(tài)算
法頂層算法底層算法宏觀步驟
算法骨干變量抽象
運算粗化微觀步驟
算法細(xì)節(jié)變量具體
運算細(xì)化ADT(抽象)運算步驟數(shù)據(jù)結(jié)構(gòu)與算法10數(shù)學(xué)層面的算法與數(shù)據(jù)結(jié)構(gòu)層面的算法數(shù)據(jù)結(jié)構(gòu)層面的算法publicObjectpop(){
if(empty())
thrownewEmptyStackException();
ObjecttopElement=stack[top];
returntopElement;}涉及對具體數(shù)據(jù)結(jié)構(gòu)的操作數(shù)據(jù)結(jié)構(gòu)與算法11數(shù)學(xué)層面的算法不涉及對具體數(shù)據(jù)結(jié)構(gòu)的操作只使用數(shù)據(jù)結(jié)構(gòu)ADT的接口數(shù)據(jù)結(jié)構(gòu)與算法12算法與數(shù)據(jù)結(jié)構(gòu)的關(guān)系算法vs
抽象的邏輯的數(shù)據(jù)結(jié)構(gòu)四染色算法vs
具體的數(shù)據(jù)結(jié)構(gòu)四染色算法vs
邏輯的數(shù)據(jù)結(jié)構(gòu)
(往往由控制結(jié)構(gòu)得到體現(xiàn))whileifelseifdo數(shù)據(jù)結(jié)構(gòu)與算法13算法分析的方法
漸進時間復(fù)雜度平均時間復(fù)雜度
一般的分析方法遞歸方程的求解數(shù)據(jù)結(jié)構(gòu)與算法14四染色算法的分析例四染色回溯算法4*4*4……4n=4nT(n)=O(4n)數(shù)據(jù)結(jié)構(gòu)與算法15voidhanoi(intn,charx,chary,charz){//將塔座x上按直徑由小到大且至上而下編號為1至n//的n個圓盤按規(guī)則搬到塔座z上,y可用作輔助塔座。
if(n==1)move(x,1,z);//將編號為1的圓盤從x移到z
else{hanoi(n-1,x,z,y);
//將x上編號為1至n-1的圓盤移到y(tǒng),z作輔助塔
move(x,n,z);
//將編號為n的圓盤從x移到zhanoi(n-1,y,x,z);
//將y上編號為1至n-1的圓盤移到z,x作輔助塔
}}Hanoi塔算法的分析數(shù)據(jù)結(jié)構(gòu)與算法16T(n)T(n-1)T(n-1)O(1)T(n)=T(n-1)+O(1)+T(n-1)=2T(n-1)+O(1)遞歸方程的求解數(shù)據(jù)結(jié)構(gòu)與算法17T(n)=2T(n-1)+O(1)
=2(2T(n-2)+O(1))+O(1)
=4T(n-2)+3O(1)
=4(2T(n-3)+O(1))+3O(1)
=8T(n-3)+7O(1)
=8(2T(n-4)+O(1))+7O(1)
=16T(n-4)+15O(1)
……T(n)=2kT(n-k)+(2k-1)O(1)數(shù)據(jù)結(jié)構(gòu)與算法18T(n)=2kT(n-k)+(2k-1)O(1)n-k=1
k=n-1T(n)=2n-1T(1)+(2n-1-1)O(1)
=2n-1O(1)+(2n-1-1)O(1)
=2·2n-1O(1)-O(1)
=(2n–1)
O(1)T(n)=O(2n)
數(shù)據(jù)結(jié)構(gòu)與算法19常用算法模式遞歸與分治算法動態(tài)規(guī)劃貪心算法回溯算法分支限界算法概率算法遺傳算法數(shù)據(jù)結(jié)構(gòu)與算法20遞歸算法數(shù)據(jù)結(jié)構(gòu)與算法21
后置遞歸法(Postponingthework)的設(shè)計思想為:假如某個問題的求解過程可以分成若干步進行,并且當(dāng)前這一步的解可以直接求得,則先求出當(dāng)前這一步的解,對于余下的問題,若問題的性質(zhì)和原問題類似,則又可遞歸求解。
數(shù)據(jù)結(jié)構(gòu)與算法22遞歸的終結(jié)狀態(tài)是,當(dāng)前的問題可以直接求解,對原問題而言,則是已走到了求解的最后一步。
鏈表是可以如此求解的一個典型例子。例如:編寫“刪除單鏈表中所有值為x
的數(shù)據(jù)元素”的算法。數(shù)據(jù)結(jié)構(gòu)與算法23
1)單鏈表是一種順序結(jié)構(gòu),必須從第一個結(jié)點起,逐個檢查每個結(jié)點的數(shù)據(jù)元素;分析:
2)從另一角度看,鏈表又是一個遞歸結(jié)構(gòu),若
L
是線性鏈表
(a1,a2,,an)
的頭指針,則
L->next是線性鏈表
(a2,,an)的頭指針。數(shù)據(jù)結(jié)構(gòu)與算法24
a1
a2
a3
an
…L例如:
a1
a2
a3
an
L
a1
a2
a3
an
L已知下列鏈表1)“a1=x”,則
L仍為刪除
x后的鏈表頭指針2)“a1≠x”,則余下問題是考慮以
L->next為頭指針的鏈表……
a1
L->nextL->next=p->nextp=L->next數(shù)據(jù)結(jié)構(gòu)與算法25void
delete_L(LinkList&L,ElemTypex){
//刪除以L為頭指針的帶頭結(jié)點的單鏈表中
//所有值為x的數(shù)據(jù)元素
if(L->next){
if(L->next->data==x){p=L->next;L->next=p->next;delete(p);delete_L(L,x);}
else
delete_L(L->next,x);}}//delete數(shù)據(jù)結(jié)構(gòu)與算法26void
delete_L(LinkList&L,ElemTypex){
//L為無頭結(jié)點的單鏈表的頭指針
if(L){
if(L->data=x){p=L;L=L->next;delete(p);delete_L(L,x);}
else
delete_L(L->next,x);}}4.遞歸函數(shù)中的尾遞歸容易消除。數(shù)據(jù)結(jié)構(gòu)與算法27voiddelete(LinkList&L,ElemTypex){
//L為帶頭結(jié)點的單鏈表的頭指針
p=L->next;pre=L;
while(p){
if(p->data=x){pre->next=p->next;free(p);p=pre->next;}
else{pre=p;p=p->next;}}}上述遞歸算法可改寫為迭代的形式數(shù)據(jù)結(jié)構(gòu)與算法28遞歸與分治算法數(shù)據(jù)結(jié)構(gòu)與算法29
若求解問題的規(guī)模為n
其次,逐步合并子問題的解,直到獲得原問題的解。
首先,把問題分解為k個性質(zhì)相同、但規(guī)模
較小的子問題(1kn),并求解這些子問題。(如果這些子問題的規(guī)模還不夠“小”
,則可以進一步分解,直到可以求解為止)
分治法的概念數(shù)據(jù)結(jié)構(gòu)與算法30PP1P2Pk……T1(n)T2(n)Tk(n)T(n)時間復(fù)雜度:T(n)=T1(n)+T2(n)+……+Tk(n)+C(n)
C(n)數(shù)據(jù)結(jié)構(gòu)與算法31voidmergeSort(RcdType&SR[],ints,intt){//將SR[s..t]歸并排序
if(s==t)return;
intm=(s+t)/2;mergeSort(SR,s,m);mergeSort(SR,m+1,t);merge(SR,s,m,t);}//mergeSort例歸并排序數(shù)據(jù)結(jié)構(gòu)與算法32T(n)T(n/2)T(n/2)Cn數(shù)據(jù)結(jié)構(gòu)與算法33T(n)=T(n/2)+T(n/2)+Cn
=2T(n/2)+Cn
=2(2T(n/4)+C(n/2))+Cn
=4T(n/4)+
Cn+Cn
=4T(n/4)+2Cn
=8T(n/8)+3Cn
=2kT(n/2k)+kCn
……2k=nk=log2nT(n)=nT(1)+log2n?Cn=Cnlog2n+d
?
nT(n)=O(nlog2n)數(shù)據(jù)結(jié)構(gòu)與算法34分治算法的設(shè)計模式divide-and-conquer(P){
if(|P|)<=n0)adhocery(P);
dividePintosmallersubinstancesP1,P2,…,Pk;
for(i=1;i<=k;i++)yi=divide-and-conquer(Pi);
returnmerge(y1,…,yk);}數(shù)據(jù)結(jié)構(gòu)與算法35最接近點對問題分析(直線上n個點,假設(shè)只有一對符合條件)算出每兩個點的距離.若排序,需O(n2),希望O(nlog2n)mS1S2p1p2p3q3q1q2d=min{|p1-p2|,|q1-q2|}數(shù)據(jù)結(jié)構(gòu)與算法36publicstaticdoublenearPair(S){n=|S|;
if(n<2)return;m=S中各點坐標(biāo)的中位數(shù);
構(gòu)造S1和S2;
//S1={x?S|x<=m},S2={x?S|x>m}d1=nearPair(S1);d2=nearPair(S2);d=min(d1,d2,q-p);
returnd;}T(n)=2T(n/2)+O(n)=O(nlog2n)數(shù)據(jù)結(jié)構(gòu)與算法37貪心算法數(shù)據(jù)結(jié)構(gòu)與算法38貪心算法的概念
在解決某一問題的過程中,貪心算法總是做出在當(dāng)前看來最好的選擇。
也就是說,貪心算法并不從整體最優(yōu)考慮,它所做出的選擇只是在某種意義上的局部最優(yōu)選擇。(最終結(jié)果并不總是整體最優(yōu))
貪心算法合理的稱謂:就急算法數(shù)據(jù)結(jié)構(gòu)與算法39四種硬幣
0.250.100.050.01
找顧客0.61
0.61-0.25=0.360.36-0.25=0.110.11-0.10=0.010.01-0.01=0.00整體最優(yōu)(幣數(shù)最少)本例的幣值結(jié)構(gòu)具有最優(yōu)子結(jié)構(gòu)性質(zhì)找錢問題數(shù)據(jù)結(jié)構(gòu)與算法40若四種硬幣
0.110.050.01
找顧客0.15
0.15-0.11=0.040.04-0.01=0.030.03-0.01=0.020.02-0.01=0.01一般可以得到整體近似最優(yōu)解0.01-0.01=0.000.15-3*0.05=0.00數(shù)據(jù)結(jié)構(gòu)與算法41貪心算法的設(shè)計模式Greedy(inputSet,Solution,target
){
Solution=?;target=?;
while(!findSolution){
x=select(inputSet);
iffeasible(Solution,x){
Solution=Solution∪x;change(target,x)}}
return
Solution;}數(shù)據(jù)結(jié)構(gòu)與算法42最小生成樹問題
(ST
G=(V,E))publicstaticvoidprim(intn,float[][]c){T=?;S={1};
while(S!=V){(i,j)=min(c[i][j])|i∈S&&j∈V-S
T=T
∪{(i,j)};
S=S
∪{j};}}數(shù)據(jù)結(jié)構(gòu)與算法43abcdegf例如:195141827168213ae12dcbgf7148531621所得生成樹權(quán)值和=
14+8+3+5+16+21
=67數(shù)據(jù)結(jié)構(gòu)與算法44回溯算法數(shù)據(jù)結(jié)構(gòu)與算法45數(shù)據(jù)結(jié)構(gòu)與算法46
回溯算法術(shù)語
1.解向量:問題解的向量表示形式。
(x1,x2,…,xk)kn,n:問題的規(guī)模。
2.約束條件
1)顯式約束:對分量xi的取值限定。
2)隱式約束:為滿足問題的解,不同分
量之間應(yīng)遵守的約束。
3.解空間:對于問題的一個實例,解向量滿足
顯式約束條件的所有多元組,構(gòu)成了該
實例的一個解空間。數(shù)據(jù)結(jié)構(gòu)與算法47
狀態(tài)空間樹
用于描述解空間的邏輯結(jié)構(gòu)樹
目標(biāo)函數(shù)與最優(yōu)解
1.目標(biāo)函數(shù):衡量問題解
“優(yōu)劣”的標(biāo)準(zhǔn)
2.最優(yōu)解:使目標(biāo)函數(shù)取極
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年護士護理教育項目勞動合同3篇
- 二零二五年生物醫(yī)藥研發(fā)與臨床試驗合同6篇
- 二零二五版智能家居系統(tǒng)集成與裝飾設(shè)計合同范本3篇
- 二零二五版高標(biāo)準(zhǔn)預(yù)制混凝土構(gòu)件供應(yīng)合同3篇
- 二零二五版租賃住宅配套設(shè)施租賃服務(wù)合同2篇
- 二零二五版家居用品經(jīng)銷代理合同范本3篇
- 二零二五版互聯(lián)網(wǎng)公司高級經(jīng)理任職及期權(quán)激勵合同3篇
- 二零二五版便利店員工工作環(huán)境與設(shè)施改善服務(wù)合同3篇
- 湖南儲備糧代儲合同(2025年度)執(zhí)行細(xì)則范本3篇
- 二零二五版地鐵站商業(yè)廣告位租賃及裝修施工合同3篇
- 2024-2025學(xué)年成都高新區(qū)七上數(shù)學(xué)期末考試試卷【含答案】
- 定額〔2025〕1號文-關(guān)于發(fā)布2018版電力建設(shè)工程概預(yù)算定額2024年度價格水平調(diào)整的通知
- 2025年浙江杭州市西湖區(qū)專職社區(qū)招聘85人歷年高頻重點提升(共500題)附帶答案詳解
- 《數(shù)學(xué)廣角-優(yōu)化》說課稿-2024-2025學(xué)年四年級上冊數(shù)學(xué)人教版
- “懂你”(原題+解題+范文+話題+技巧+閱讀類素材)-2025年中考語文一輪復(fù)習(xí)之寫作
- 2025年景觀照明項目可行性分析報告
- 2025年江蘇南京地鐵集團招聘筆試參考題庫含答案解析
- 2025年度愛讀書學(xué)長參與的讀書項目投資合同
- 電力系統(tǒng)分析答案(吳俊勇)(已修訂)
- 化學(xué)-河北省金太陽質(zhì)檢聯(lián)盟2024-2025學(xué)年高三上學(xué)期12月第三次聯(lián)考試題和答案
- 期末復(fù)習(xí)試題(試題)-2024-2025學(xué)年四年級上冊數(shù)學(xué) 北師大版
評論
0/150
提交評論