版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
2數(shù)據(jù)結(jié)構(gòu)與算法1整理ppt2.1算法2.1.1算法(algorithm)根本概念對特定問題求解步驟的一種描述,它是指令的有限序列,其中每一條指令表示一個(gè)或多個(gè)操作。它是一組嚴(yán)謹(jǐn)?shù)囟x運(yùn)算順序的規(guī)那么,并且每一個(gè)規(guī)那么都是有效的,且是明確的,此順序?qū)⒃谟邢薜拇螖?shù)下終止。算法具有有窮性、確定性、可行性、輸入和輸出等5個(gè)重要特性。2整理ppt2.1.2算法的根本要素1、對數(shù)據(jù)對象的運(yùn)算和操作算術(shù)運(yùn)算邏輯運(yùn)算關(guān)系運(yùn)算數(shù)據(jù)傳輸2、算法的控制結(jié)構(gòu)算法中各操作之間的執(zhí)行順序描述算法的工具通常有傳統(tǒng)流程圖、N-S結(jié)構(gòu)化流程圖、算法描述語言等一個(gè)算法一般可以用順序、選擇、循環(huán)三種根本機(jī)構(gòu)組合而成。3整理ppt2.1.3算法設(shè)計(jì)根本方法列舉法歸納法遞推遞歸〔以簡潔的形式設(shè)計(jì)和描述算法〕減半遞推技術(shù)回溯法4整理ppt2.2算法復(fù)雜度2.2.1時(shí)間復(fù)雜度依據(jù)算法算法編制的程序在計(jì)算機(jī)上運(yùn)行時(shí)所消耗的時(shí)間來度量。通常有事后統(tǒng)計(jì)法和事前分析估算法。一個(gè)算法是由控制結(jié)構(gòu)〔順序、分支和循環(huán)〕和原操作構(gòu)成的,算法時(shí)間取決于兩者的綜合效果。算法中根本操作重復(fù)執(zhí)行次數(shù)n和算法執(zhí)行時(shí)間同步增長,稱作算法的時(shí)間復(fù)雜度。5整理ppt2.2.2算法的空間復(fù)雜度一般是指執(zhí)行這個(gè)算法所需要的內(nèi)存空間一個(gè)算法所占用的存儲(chǔ)空間包括算法程序所占的空間、輸入的初始數(shù)據(jù)所占的存儲(chǔ)空間以及某種數(shù)據(jù)結(jié)構(gòu)所需要的附加存儲(chǔ)空間一個(gè)上機(jī)執(zhí)行的程序除了需要存儲(chǔ)空間來存放本身所用指令、常數(shù)、變量和輸入數(shù)據(jù)外,也需要一些對數(shù)據(jù)進(jìn)行操作的工作單元和存儲(chǔ)一些為實(shí)現(xiàn)計(jì)算所需信息的輔助空間。6整理ppt例題講解7整理ppt算法的時(shí)間復(fù)雜度是指〔〕A)執(zhí)行算法程序所需要的時(shí)間B)算法程序的長度C)算法執(zhí)行過程中所需要的根本運(yùn)算次數(shù)D)算法程序中的指令條數(shù)算法的空間復(fù)雜度是指〔〕A)算法程序的長度B)算法程序中的指令條數(shù)C)算法程序所占的存儲(chǔ)空間D)執(zhí)行過程中所需的存儲(chǔ)空間在計(jì)算機(jī)中,算法是指〔〕A)加工方法 B)解題方案的準(zhǔn)確而完整的描述C)排序方法 D)查詢方法8整理ppt算法分析的目的是〔〕A)找出數(shù)據(jù)結(jié)構(gòu)的合理性 B)找出算法中輸入和輸出之間的關(guān)系C)分析算法的易懂性和可靠性 D)分析算法的效率以求改進(jìn)以下表達(dá)中正確的選項(xiàng)是〔〕A)算法的效率只與問題的規(guī)模有關(guān),而與數(shù)據(jù)的存儲(chǔ)結(jié)構(gòu)無關(guān)。B)算法的時(shí)間復(fù)雜度是指執(zhí)行算法所需的計(jì)算工作量。C)數(shù)據(jù)的邏輯結(jié)構(gòu)與存儲(chǔ)結(jié)構(gòu)是一一對應(yīng)的。D)算法的時(shí)間復(fù)雜度與空間復(fù)雜度一定相關(guān)。算法的根本特征是可行性、確定性、〔〕輸入、輸出。9整理ppt2.2數(shù)據(jù)結(jié)構(gòu)數(shù)據(jù)結(jié)構(gòu)的定義數(shù)據(jù)的邏輯結(jié)構(gòu)和存儲(chǔ)結(jié)構(gòu)數(shù)據(jù)結(jié)構(gòu)的圖形表示線性結(jié)構(gòu)與非線性結(jié)構(gòu)10整理ppt
數(shù)據(jù)結(jié)構(gòu)是一門研究數(shù)據(jù)組織、存儲(chǔ)和運(yùn)算的一般方法的學(xué)科。數(shù)據(jù)結(jié)構(gòu)是反映數(shù)據(jù)元素之間關(guān)系的數(shù)據(jù)元素集合的表示,即數(shù)據(jù)的組織形式。數(shù)據(jù)結(jié)構(gòu)定義11整理ppt數(shù)據(jù)元素(DataElement)數(shù)據(jù)元素是數(shù)據(jù)的根本單位,即數(shù)據(jù)集合中的個(gè)體。有時(shí)一個(gè)數(shù)據(jù)元數(shù)可由假設(shè)干數(shù)據(jù)項(xiàng)(DataItem)組成。數(shù)據(jù)項(xiàng)是數(shù)據(jù)的最小單位。數(shù)據(jù)元素亦稱節(jié)點(diǎn)或記錄。12整理ppt數(shù)據(jù)結(jié)構(gòu)主要研究以下三個(gè)方面的問題:數(shù)據(jù)的邏輯結(jié)構(gòu)數(shù)據(jù)的存儲(chǔ)結(jié)構(gòu)對各種數(shù)據(jù)結(jié)構(gòu)進(jìn)行的運(yùn)算
13整理ppt數(shù)據(jù)的邏輯結(jié)構(gòu)數(shù)據(jù)的邏輯結(jié)構(gòu)是指反映數(shù)據(jù)元素之間邏輯關(guān)系的數(shù)據(jù)結(jié)構(gòu)。兩個(gè)要素1〕數(shù)據(jù)元素集合2〕數(shù)據(jù)元素之間的關(guān)系表示形式B=(D,R)其中B表示一個(gè)數(shù)據(jù)結(jié)構(gòu)D表示數(shù)據(jù)元素集合R表示數(shù)據(jù)元素之間的關(guān)系14整理ppt數(shù)據(jù)的存儲(chǔ)結(jié)構(gòu)數(shù)據(jù)的存儲(chǔ)結(jié)構(gòu)也稱數(shù)據(jù)的物理結(jié)構(gòu),是數(shù)據(jù)的邏輯結(jié)構(gòu)在計(jì)算機(jī)存儲(chǔ)空間的存放形式。數(shù)據(jù)結(jié)構(gòu)的存儲(chǔ)方式:
1.順序存儲(chǔ)方法
2.鏈?zhǔn)酱鎯?chǔ)方法
3.索引存儲(chǔ)方法
4.散列存儲(chǔ)方法15整理ppt數(shù)據(jù)結(jié)構(gòu)的圖形表示
數(shù)據(jù)結(jié)構(gòu)的表示形式
1)二元關(guān)系表
2)圖形
B=(D,R)D={1,2,3,4}R={(1,2),(1,3),(1,4),(2,3)(3,4),(2,4)}142316整理ppt線性結(jié)構(gòu)與非線性結(jié)構(gòu)根據(jù)數(shù)據(jù)結(jié)構(gòu)中各數(shù)據(jù)元素之間前后關(guān)系的復(fù)雜程度,將數(shù)據(jù)結(jié)構(gòu)分為線性結(jié)構(gòu)與非線性結(jié)構(gòu)。線性結(jié)構(gòu)定義:如果一個(gè)非空的數(shù)據(jù)結(jié)構(gòu)滿足以下兩個(gè)條件:1.有且只有一個(gè)根節(jié)點(diǎn)2.每個(gè)節(jié)點(diǎn)最多有一個(gè)直接前驅(qū),也最多有一個(gè)直接后繼。那么稱該數(shù)據(jù)結(jié)構(gòu)為線性結(jié)構(gòu),又稱線性表。在一個(gè)線性結(jié)構(gòu)中插入或刪除任何一個(gè)節(jié)點(diǎn)還應(yīng)該是線性結(jié)構(gòu)。17整理ppt例題例1:以下表達(dá)正確的選項(xiàng)是〔〕〔2007.9〕A)程序執(zhí)行的效率與數(shù)據(jù)的存儲(chǔ)結(jié)構(gòu)密切相關(guān)B〕程序執(zhí)行的效率只取決于程序的控制結(jié)構(gòu)C〕程序執(zhí)行的效率只取決于所處理的數(shù)據(jù)量D〕以上三種說法都不對例2數(shù)據(jù)結(jié)構(gòu)分為線性結(jié)構(gòu)和非線性結(jié)構(gòu),帶鏈的隊(duì)列屬于_____結(jié)構(gòu)。(2006.9)
18整理ppt2.3線性表2.3.1線性表的定義線性表是n個(gè)元素的有限序列,它們之間的關(guān)系可以排成一個(gè)線性序列:
a1,a2,……,ai,……,an其中n稱作表的長度,當(dāng)n=0時(shí),稱作空表。19整理ppt線性表的特點(diǎn):1.線性表中所有元素的性質(zhì)相同。2.除第一個(gè)和最后一個(gè)數(shù)據(jù)元素之外,其它數(shù)據(jù)元素有且僅有一個(gè)前驅(qū)和一個(gè)后繼。第一個(gè)數(shù)據(jù)元素?zé)o前驅(qū),最后一個(gè)數(shù)據(jù)元素?zé)o后繼。3.數(shù)據(jù)元素在表中的位置只取決于它自身的序號(hào)。在線性表上常用的運(yùn)算有:初始化、求長度、取元素、修改、前插、刪除、檢索、排序。20整理ppt線性表及其順序存儲(chǔ)結(jié)構(gòu)線性表的順序存儲(chǔ)結(jié)構(gòu)
線性表的順序存儲(chǔ)是指在內(nèi)存中用地址連續(xù)的一塊存儲(chǔ)空間順序存放線性表的各元素。用這種存儲(chǔ)形式存儲(chǔ)的線性表稱其為順序表。21整理ppt元素an……..元素ai……..元素a2元素a1bb+mb+(i-1)*mb+(maxlen-1)*m存儲(chǔ)地址內(nèi)存狀態(tài)Loc(元素i)=b+〔i-1)*m順序存儲(chǔ)結(jié)構(gòu)示意圖(順序表):首地址起始地址基地址每個(gè)元素所占用的存儲(chǔ)單元個(gè)數(shù)22整理ppt2.3.2線性表的順序存儲(chǔ)結(jié)構(gòu)特點(diǎn):
1、線性表中數(shù)據(jù)元素類型一致,只有數(shù)據(jù)域,存儲(chǔ)空間利用率高。
2、所有元素所占的存儲(chǔ)空間是連續(xù)的
3、各數(shù)據(jù)元素在存儲(chǔ)空間中是按邏輯順序依次存放的
2.做插入、刪除時(shí)需移動(dòng)大量元素。
3.空間估計(jì)不明時(shí),按最大空間分配。23整理ppt元素a1元素a2……..元素ai+1……..01i線性表的順序存儲(chǔ)結(jié)構(gòu)——可用C語言中的一維數(shù)組來描述.intV[M];
/*V是數(shù)組的名字,M是數(shù)組大小,假設(shè)數(shù)組中的元素是整型類型*/第i個(gè)元素的ai存儲(chǔ)地址:Loc(ai)=Loc(a1)+(i-1)*kV[0]V[1]V[i]V[m-1]24整理ppt…..a2a1an…..ai+1ai01i-1in-11-1插入運(yùn)算ai-1…..a2a1alength…ai+1aixai-1…..a2a1
aiai+1…alength
alength……ai+1aix25整理ppt…..a2a1an…..ai+1ai01i-1in-11-2刪除運(yùn)算ai-1…..a2a1alength…ai+1aixai-1…..a2a1
ai
…alength
alength…aix…26整理ppt插入算法的分析假設(shè)線性表中含有n個(gè)數(shù)據(jù)元素,在進(jìn)行插入操作時(shí),假設(shè)假定在n+1個(gè)位置上插入元素的可能性均等,那么平均移動(dòng)元素的個(gè)數(shù)為:27整理ppt刪除算法的分析在進(jìn)行刪除操作時(shí),假設(shè)假定刪除每個(gè)元素的可能性均等,那么平均移動(dòng)元素的個(gè)數(shù)為:分析結(jié)論順序存儲(chǔ)結(jié)構(gòu)表示的線性表,在做插入或刪除操作時(shí),平均需要移動(dòng)大約一半的數(shù)據(jù)元素。當(dāng)線性表的數(shù)據(jù)元素量較大,并且經(jīng)常要對其做插入或刪除操作時(shí),這一點(diǎn)需要值得考慮。28整理ppt例題講解29整理ppt鏈表不具有的特點(diǎn)是不必事先估計(jì)存儲(chǔ)空間可隨機(jī)訪問任一元素C)插入刪除不需要移動(dòng)元素 D)所需空間與線性表長度成正比數(shù)據(jù)結(jié)構(gòu)分為邏輯結(jié)構(gòu)與存儲(chǔ)結(jié)構(gòu),線性鏈表屬于【1】
。數(shù)據(jù)的邏輯結(jié)構(gòu)有線性結(jié)構(gòu)和【1】
兩大類。30整理ppt順序存儲(chǔ)方法是把邏輯上相鄰的結(jié)點(diǎn)存儲(chǔ)在物理位置
【2】的存儲(chǔ)單元中。數(shù)據(jù)處理的最小單位是
A)數(shù)據(jù) B)數(shù)據(jù)元素C)數(shù)據(jù)項(xiàng) D)數(shù)據(jù)結(jié)構(gòu)數(shù)據(jù)結(jié)構(gòu)作為計(jì)算機(jī)的一門學(xué)科,主要研究數(shù)據(jù)的邏輯結(jié)構(gòu)、對各種數(shù)據(jù)結(jié)構(gòu)進(jìn)行的運(yùn)算,以及
A)數(shù)據(jù)的存儲(chǔ)結(jié)構(gòu) B)計(jì)算方法C)數(shù)據(jù)映象D)邏輯存儲(chǔ)線性表的順序存儲(chǔ)結(jié)構(gòu)和線性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)分別是
A)順序存取的存儲(chǔ)結(jié)構(gòu)、順序存取的存儲(chǔ)結(jié)構(gòu)
B)隨機(jī)存取的存儲(chǔ)結(jié)構(gòu)、順序存取的存儲(chǔ)結(jié)構(gòu)
C)隨機(jī)存取的存儲(chǔ)結(jié)構(gòu)、隨機(jī)存取的存儲(chǔ)結(jié)構(gòu)
D)任意存取的存儲(chǔ)結(jié)構(gòu)、任意存取的存儲(chǔ)結(jié)構(gòu)31整理ppt根據(jù)數(shù)據(jù)結(jié)構(gòu)中各數(shù)據(jù)元素之間前后件關(guān)系的復(fù)雜程度,一般將數(shù)據(jù)結(jié)構(gòu)分成A)動(dòng)態(tài)結(jié)構(gòu)和靜態(tài)結(jié)構(gòu) B)緊湊結(jié)構(gòu)和非緊湊結(jié)構(gòu)C)線性結(jié)構(gòu)和非線性結(jié)構(gòu)D)內(nèi)部結(jié)構(gòu)和外部結(jié)構(gòu)數(shù)據(jù)結(jié)構(gòu)包括數(shù)據(jù)的邏輯結(jié)構(gòu)、數(shù)據(jù)的【2】以及對數(shù)據(jù)的操作運(yùn)算。數(shù)據(jù)的根本單位是【5】。32整理ppt以下表達(dá)中,錯(cuò)誤的選項(xiàng)是A)數(shù)據(jù)的存儲(chǔ)結(jié)構(gòu)與數(shù)據(jù)處理的效率密切相關(guān)B)數(shù)據(jù)的存儲(chǔ)結(jié)構(gòu)與數(shù)據(jù)處理的效率無關(guān)C)數(shù)據(jù)的存儲(chǔ)結(jié)構(gòu)在計(jì)算機(jī)中所占的空間不一定是連續(xù)的D)一種數(shù)據(jù)的邏輯結(jié)構(gòu)可以有多種存儲(chǔ)結(jié)構(gòu)數(shù)據(jù)的存儲(chǔ)結(jié)構(gòu)是指A〕數(shù)據(jù)所占的存儲(chǔ)空間B〕數(shù)據(jù)的邏輯結(jié)構(gòu)在計(jì)算機(jī)中的表示C〕數(shù)據(jù)在計(jì)算機(jī)中的順序存儲(chǔ)方式D〕存儲(chǔ)在外存中的數(shù)據(jù)33整理ppt鏈表不具有的特點(diǎn)是A)不必事先估計(jì)存儲(chǔ)空間B)可隨機(jī)訪問任一元素C)插入刪除不需要移動(dòng)元素 D)所需空間與線性表長度成正比順序存儲(chǔ)方法是把邏輯上相鄰的結(jié)點(diǎn)存儲(chǔ)在物理位置
【2】的存儲(chǔ)單元中。長度為n的順序存儲(chǔ)線性表中,當(dāng)在任何位置上插入一個(gè)元素概率都相等時(shí),插入一個(gè)元素所需移動(dòng)元素的平均個(gè)數(shù)為【1】
。34整理ppt線性表L=(a1,a2,a3,…ai,…an),以下說法正確的選項(xiàng)是A)每個(gè)元素都有一個(gè)直接前驅(qū)和直接后繼B)線性表中至少要有一個(gè)元素C)表中諸元素的排列順序必須是由小到大或由大到小D)除第一個(gè)元素和最后一個(gè)元素外,其余每個(gè)元素都有一個(gè)且只有一個(gè)直接前驅(qū)和直接后繼線性表的順序存儲(chǔ)結(jié)構(gòu)和線性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)分別是A)順序存取的存儲(chǔ)結(jié)構(gòu)、順序存取的存儲(chǔ)結(jié)構(gòu)B)隨機(jī)存取的存儲(chǔ)結(jié)構(gòu)、順序存取的存儲(chǔ)結(jié)構(gòu)C)隨機(jī)存取的存儲(chǔ)結(jié)構(gòu)、隨機(jī)存取的存儲(chǔ)結(jié)構(gòu)D)任意存取的存儲(chǔ)結(jié)構(gòu)、任意存取的存儲(chǔ)結(jié)構(gòu)35整理ppt根據(jù)數(shù)據(jù)結(jié)構(gòu)中各數(shù)據(jù)元素之間前后件關(guān)系的復(fù)雜程度,一般將數(shù)據(jù)結(jié)構(gòu)分成A)動(dòng)態(tài)結(jié)構(gòu)和靜態(tài)結(jié)構(gòu) B)緊湊結(jié)構(gòu)和非緊湊結(jié)構(gòu)C)線性結(jié)構(gòu)和非線性結(jié)構(gòu)D)內(nèi)部結(jié)構(gòu)和外部結(jié)構(gòu)當(dāng)線性表采用順序存儲(chǔ)結(jié)構(gòu)實(shí)現(xiàn)存儲(chǔ)時(shí),其主要特點(diǎn)是【1】。線性表假設(shè)采用鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)時(shí),要求內(nèi)存中可用存儲(chǔ)單元的地址A)必須是連續(xù)的 B)局部地址必須是連續(xù)的C)一定是不連續(xù)的D)連續(xù)不連續(xù)都可以36整理ppt以下表達(dá)中,錯(cuò)誤的選項(xiàng)是A)數(shù)據(jù)的存儲(chǔ)結(jié)構(gòu)與數(shù)據(jù)處理的效率密切相關(guān)B)數(shù)據(jù)的存儲(chǔ)結(jié)構(gòu)與數(shù)據(jù)處理的效率無關(guān)C)數(shù)據(jù)的存儲(chǔ)結(jié)構(gòu)在計(jì)算機(jī)中所占的空間不一定是連續(xù)的D)一種數(shù)據(jù)的邏輯結(jié)構(gòu)可以有多種存儲(chǔ)結(jié)構(gòu)37整理ppt2.4棧和隊(duì)列2.4.1棧和隊(duì)列的定義
棧和隊(duì)列是兩種特殊的線性表,它們是運(yùn)算時(shí)要受到某些限制的線性表,故也稱為限定性的數(shù)據(jù)結(jié)構(gòu)。38整理ppt2.4.1.1棧的定義棧:限定只能在表的一端進(jìn)行插入和刪除的特殊的線性表,此種結(jié)構(gòu)稱為后進(jìn)先出設(shè)棧s=〔a1,a2,...,ai,...,an〕,其中a1是棧底元素,an是棧頂元素。棧頂〔top):允許插入和刪除的一端;約定top始終指向新數(shù)據(jù)元素將存放的位置。棧底〔bottom):不允許插入和刪除的一端。a1a2….an進(jìn)棧出棧棧頂棧底39整理ppt隊(duì)列的主要運(yùn)算〔1〕設(shè)置一個(gè)空隊(duì)列;〔2〕插入一個(gè)新的隊(duì)尾元素,稱為進(jìn)隊(duì);〔3〕刪除隊(duì)頭元素,稱為出隊(duì);〔4〕讀取隊(duì)頭元素;2.4.1.2隊(duì)列的定義定義:一種特殊的線性結(jié)構(gòu),限定只能在表的一端進(jìn)行插入,在表的另一端進(jìn)行刪除的線性表。此種結(jié)構(gòu)稱為先進(jìn)先出〔FIFO〕表。a1,
a2,
a3,
a4,…………
an-1,
an
隊(duì)列示意圖隊(duì)頭隊(duì)尾40整理ppt2.4.2棧的順序存儲(chǔ)結(jié)構(gòu)及其根本運(yùn)算a2a1a1a2top
用順序存儲(chǔ)結(jié)構(gòu)表示的棧。
順序棧用一組連續(xù)的存儲(chǔ)單元存放自棧底到棧頂?shù)臄?shù)據(jù)元素,一般用一維數(shù)組表示,設(shè)置一個(gè)簡單變量top指示棧頂位置,稱為棧頂指針,它始終指向待插入元素的位置。根本運(yùn)算:壓〔進(jìn)〕棧:PUSH出棧:POP41整理ppt
3210(a)rear=front=-1(隊(duì)空)e3e4(c)e1,e2出隊(duì),e4入隊(duì)
隊(duì)滿rear=4fronte1e2e3
(b)rearfront(b)e1,e2,e3入隊(duì)隊(duì)空時(shí),令rear=front=-1,當(dāng)有新元素入隊(duì)時(shí),尾指針加1,當(dāng)有元素出隊(duì)時(shí),頭指針加1。故在非空隊(duì)列中,頭指針始終指向隊(duì)頭元素前一個(gè)位置,而尾指針始終指向隊(duì)尾元素的位置2.4.3隊(duì)列的順序存儲(chǔ)結(jié)構(gòu)及其根本運(yùn)算42整理ppt例題講解43整理ppt棧和隊(duì)列的共同特點(diǎn)是A)都是先進(jìn)先出B)都是先進(jìn)后出C)只允許在端點(diǎn)處插入和刪除元素D)沒有共同點(diǎn)如果進(jìn)棧序列為e1,e2,e3,e4,那么可能的出棧序列是A)e3,e1,e4,e2 B)e2,e4,e3,e1C)e3,e4,e1,e2 D)任意順序一些重要的程序語言(如C語言和Pascal語言)允許過程的遞歸調(diào)用。而實(shí)現(xiàn)遞歸調(diào)用中的存儲(chǔ)分配通常用A)棧 B)堆C)數(shù)組 D)鏈表44整理ppt棧底至棧頂依次存放元素A、B、C、D,在第五個(gè)元素E入棧前,棧中元素可以出棧,那么出棧序列可能是A)ABCED B)DCBEAC)DBCEA D)CDABE棧通常采用的兩種存儲(chǔ)結(jié)構(gòu)是A)線性存儲(chǔ)結(jié)構(gòu)和鏈表存儲(chǔ)結(jié)構(gòu) B)散列方式和索引方式C)鏈表存儲(chǔ)結(jié)構(gòu)和數(shù)組D)線性存儲(chǔ)結(jié)構(gòu)和非線性存儲(chǔ)結(jié)構(gòu)棧和隊(duì)列通常采用的存儲(chǔ)結(jié)構(gòu)是【1】。以下數(shù)據(jù)結(jié)構(gòu)中,按先進(jìn)后出原那么組織數(shù)據(jù)的是A)線性鏈表B)棧C)循環(huán)鏈表 D)順序表45整理ppt由兩個(gè)棧共享一個(gè)存儲(chǔ)空間的好處是A)減少存取時(shí)間,降低下溢發(fā)生的機(jī)率B)節(jié)省存儲(chǔ)空間,降低上溢發(fā)生的機(jī)率C)減少存取時(shí)間,降低上溢發(fā)生的機(jī)率D)節(jié)省存儲(chǔ)空間,降低下溢發(fā)生的機(jī)率以下關(guān)于棧的表達(dá)中正確的選項(xiàng)是A〕在棧中只能插入數(shù)據(jù)B〕在棧中只能刪除數(shù)據(jù)C〕棧是先進(jìn)先出的線性表D〕棧是后進(jìn)先出的線性表以下關(guān)于隊(duì)列的表達(dá)中正確的選項(xiàng)是A〕在隊(duì)列中只能插入數(shù)據(jù)B〕在隊(duì)列中只能刪除數(shù)據(jù)C〕隊(duì)列是先進(jìn)先出的線性表D〕隊(duì)列是后進(jìn)先出的線性表46整理ppt2.5鏈表線性單鏈表雙向鏈表循環(huán)鏈表結(jié)構(gòu)及其根本運(yùn)算47整理ppt2.5.1線性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)
將線性表的元素放到一個(gè)具有頭指針的鏈表中,鏈表中每個(gè)結(jié)點(diǎn)包含數(shù)據(jù)域和指針域。
數(shù)據(jù)域存放數(shù)據(jù),指針域存放后繼結(jié)點(diǎn)的地址,最后一個(gè)結(jié)點(diǎn)的指針域?yàn)榭铡_壿嬌舷噜彽臄?shù)據(jù)元素在內(nèi)存中的物理存儲(chǔ)空間不一定相鄰。48整理ppt上圖的線性表為ZHAO,QIAN,SUN,LI,ZHOU,WU,ZHENG,WANG49整理ppt線性鏈表表示法:50整理ppt鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)的特點(diǎn)
插入、刪除靈活方便,不需要移動(dòng)結(jié)點(diǎn),只要改變結(jié)點(diǎn)中指針域的值即可。適合于線性表是動(dòng)態(tài)變化的,不進(jìn)行頻繁查找操作、但經(jīng)常進(jìn)行插入刪除時(shí)使用。
鏈表的查找只能從頭指針開始順序查找。
51整理ppta1a2an∧a3L…..線性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)可用C語言中的“結(jié)構(gòu)指針〞來描述帶頭結(jié)點(diǎn)的線性鏈表datanexttypedefstructLNode{intdata;StructLNode*next;}JD;52整理pptbabaxPP單鏈表的插入運(yùn)算S在P所指向的結(jié)點(diǎn)之后插入新的結(jié)點(diǎn)53整理pptbabax∧anaia1a2PPai-1xL單鏈表的插入運(yùn)算S54整理pptai-1a1aiai+1Lp單鏈表的刪除運(yùn)算ai-1a1aiai+1Lpq刪除p指針指向結(jié)點(diǎn)的后一個(gè)結(jié)點(diǎn)q指向p的后繼結(jié)點(diǎn)2.修改p結(jié)點(diǎn)的指針域3.刪除并釋放結(jié)點(diǎn)ai-1a1aiai+1Lpq55整理pptvoidlbsc(JD*p)/*刪除p指針指向結(jié)點(diǎn)的后一個(gè)結(jié)點(diǎn)*/{JD*q;if(p->next!=NULL){q=p->next;/*q指向p的后繼結(jié)點(diǎn)*/
p->next=q->next;/*修改p結(jié)點(diǎn)的指針域*/free(q);/*刪除并釋放結(jié)點(diǎn)*/}}單鏈表的刪除運(yùn)算56整理ppt線性鏈表的查找操作:設(shè)無表頭結(jié)點(diǎn)的線性鏈表的頭指針為h,沿著鏈表的開始往后找結(jié)點(diǎn)x,假設(shè)找到,那么返回該結(jié)點(diǎn)在鏈表中的位置,否那么返回空地址。JD*lbcz(JD*h,intx){JD*p;p=h;while(p!=NULL&&p->data!=x)p=p->next;return(p);}57整理ppt2.5.2循環(huán)鏈表:
首尾相接的鏈表。將最后一個(gè)結(jié)點(diǎn)的空指針改為指向頭結(jié)點(diǎn),從任一結(jié)點(diǎn)出發(fā)均可找到其它結(jié)點(diǎn)。a1a2an∧a3L…..帶頭結(jié)點(diǎn)的單鏈表a1a2ana3L…..循環(huán)單鏈表58整理ppt2.5.3雙向鏈表在每個(gè)結(jié)點(diǎn)中設(shè)置兩個(gè)指針,一個(gè)指向后繼,一個(gè)指向前驅(qū)。可直接確定一個(gè)結(jié)點(diǎn)的前驅(qū)和后繼結(jié)點(diǎn)??商岣咝?。datanextbefore59整理ppt例題講解60整理ppt用鏈表表示線性表的優(yōu)點(diǎn)是
A)便于隨機(jī)存取B)花費(fèi)的存儲(chǔ)空間較順序存儲(chǔ)少
C)便于插入和刪除操作D)數(shù)據(jù)元素的物理順序與邏輯順序相同在單鏈表中,增加頭結(jié)點(diǎn)的目的是
A)方便運(yùn)算的實(shí)現(xiàn)
B)使單鏈表至少有一個(gè)結(jié)點(diǎn)
C)標(biāo)識(shí)表結(jié)點(diǎn)中首結(jié)點(diǎn)的位置
D)說明單鏈表是線性表的鏈?zhǔn)酱鎯?chǔ)實(shí)現(xiàn)61整理ppt非空的循環(huán)單鏈表head的尾結(jié)點(diǎn)(由p所指向),滿足A)p->next==NULL B)p==NULLC)p->next=head D)p=head循環(huán)鏈表的主要優(yōu)點(diǎn)是A)不再需要頭指針了B)從表中任一結(jié)點(diǎn)出發(fā)都能訪問到整個(gè)鏈表C)在進(jìn)行插入、刪除運(yùn)算時(shí),能更好的保證鏈表不斷開D)某個(gè)結(jié)點(diǎn)的位置后,能夠容易的找到它的直接前件62整理ppt2.6樹樹的根本概念二叉樹的定義及其存儲(chǔ)結(jié)構(gòu)二叉樹的前序、中序和后序遍歷63整理ppt2.6.1樹的定義由一個(gè)或多個(gè)結(jié)點(diǎn)組成的有限集合。僅有一個(gè)根結(jié)點(diǎn),結(jié)點(diǎn)間有明顯的層次結(jié)構(gòu)關(guān)系。
A
C
GT2D
HIT3J
M
BEL
KT1F現(xiàn)實(shí)世界中,能用樹的結(jié)構(gòu)表示的例子:學(xué)校的行政關(guān)系、書的層次結(jié)構(gòu)、人類的家族血緣關(guān)系等。64整理ppt介紹幾個(gè)概念:結(jié)點(diǎn)〔Node〕:樹中的元素,包含數(shù)據(jù)項(xiàng)及假設(shè)干指向其子樹的分支。結(jié)點(diǎn)的度〔Degree〕:結(jié)點(diǎn)擁有的子樹數(shù)。結(jié)點(diǎn)的層次:從根結(jié)點(diǎn)開始算起,根為第一層。葉子〔Leaf〕:度為零的結(jié)點(diǎn),也稱端結(jié)點(diǎn)。孩子〔Child〕:結(jié)點(diǎn)子樹的根稱為該結(jié)點(diǎn)的孩子結(jié)點(diǎn)。兄弟〔Sibling〕:同一雙親的孩子。雙親〔Parent〕:孩子結(jié)點(diǎn)的上層結(jié)點(diǎn),稱為這些結(jié)點(diǎn)的雙親。深度〔Depth):樹中結(jié)點(diǎn)的最大層次數(shù)。森林〔Forest〕:M棵互不相交的樹的集合。
A
C
GT2D
HIT3J
M
BEL
KT1F65整理ppt2.6.2二叉樹〔BinaryTree〕1、二叉樹的定義及其性質(zhì)
(1)二叉樹的定義二叉樹的五種根本形態(tài)二叉樹一種特殊的樹型結(jié)構(gòu),特點(diǎn)是樹中每個(gè)結(jié)點(diǎn)只有兩棵子樹,且子樹有左右之分,次序不能顛倒。
空二叉樹
僅有根結(jié)點(diǎn)
右子樹為空
左子樹為空左右子樹均非空因?yàn)闃涞拿總€(gè)結(jié)點(diǎn)的度不同,存儲(chǔ)困難,使對樹的處理算法很復(fù)雜。所以引出二叉樹的討論。66整理ppt二叉數(shù)是n(n
0)個(gè)結(jié)點(diǎn)的有限集合。它或?yàn)榭諗?shù)(n=0),或由一個(gè)根結(jié)點(diǎn)和兩棵分別稱為根的左子樹和右子樹的互不相交的二叉樹組成。
特別要注意:二叉數(shù)不是樹的特殊情況。aabb兩棵不同的二叉數(shù)67整理pptA、二叉樹的第i層上至多有2i-1〔i1〕個(gè)結(jié)點(diǎn)。(2)二叉樹的根本性質(zhì)423167891011121314155第三層上(i=3),有23-1=4個(gè)節(jié)點(diǎn)。第四層上(i=4),有24-1=8個(gè)節(jié)點(diǎn)。68整理pptA、二叉樹的第i層上至多有2i-1〔i1〕個(gè)結(jié)點(diǎn)。B、深度為h的二叉樹中至多含有2h-1個(gè)結(jié)點(diǎn)。(2)二叉樹的根本性質(zhì)423167891011121314155此樹的深度h=4,共有24-1=15個(gè)節(jié)點(diǎn)。69整理pptA、二叉樹的第i層上至多有2i-1〔i1〕個(gè)結(jié)點(diǎn)。B、深度為h的二叉樹中至多含有2h-1個(gè)結(jié)點(diǎn)。C、假設(shè)在任意一棵二叉樹中,有n0個(gè)葉子結(jié)點(diǎn),有n2個(gè)度為2的結(jié)點(diǎn),那么:n0=n2+1(2)二叉樹的根本性質(zhì)423167891011121314155n0=8n2=770整理ppt〔3〕滿二叉樹423167891011121314155特點(diǎn):每一層上都含有最大結(jié)點(diǎn)數(shù)。71整理ppt423167891011125
非完全二叉樹〔4〕完全二叉樹423167891011125
完全二叉樹特點(diǎn):除最后一層外,每一層都取最大結(jié)點(diǎn)數(shù),最后一層結(jié)點(diǎn)都集中在該層最左邊的假設(shè)干位置。72整理ppt〔5〕樹與二叉樹的區(qū)別A.樹中結(jié)點(diǎn)的最大度數(shù)沒有限制,二叉樹結(jié)點(diǎn)最大度數(shù)為2。B.樹的結(jié)點(diǎn)無左、右之分,二叉樹的結(jié)點(diǎn)子樹有明確的左、右之分。
樹
二叉樹73整理ppt2、二叉樹的存儲(chǔ)結(jié)構(gòu)
(2)鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)T[16]假設(shè)父結(jié)點(diǎn)在數(shù)組中i下標(biāo)處,其左孩子在2*i處,右孩子在2*i+1處。11ABcFED
●●●●●●●●●124
8
910563712131415(1)順序存儲(chǔ)結(jié)構(gòu)(1)順序存儲(chǔ)結(jié)構(gòu)2h-1=24-1=15用一組連續(xù)的存儲(chǔ)單元存放二叉樹的數(shù)據(jù)元素。結(jié)點(diǎn)在數(shù)組中的相對位置蘊(yùn)含著結(jié)點(diǎn)之間的關(guān)系。0000FE000DC0BA15141312111098765432100一般二叉樹必須按完全二叉樹的形式存儲(chǔ),將造成存儲(chǔ)的浪費(fèi)。74整理ppt2.6.3二叉樹的遍歷查找某個(gè)結(jié)點(diǎn),或?qū)Χ鏄渲腥拷Y(jié)點(diǎn)進(jìn)行某種處理,就需要遍歷?!?〕遍歷定義及遍歷算法遍歷是指按某條搜索路線尋訪樹中每個(gè)結(jié)點(diǎn),且每個(gè)結(jié)點(diǎn)只被訪問一次。按先左后右的原那么,一般使用三種遍歷:先序遍歷(DLR):訪問根結(jié)點(diǎn),按先序遍歷左子樹,按先序遍歷右子樹。中序遍歷(LDR):按中序遍歷左子樹,訪問根結(jié)點(diǎn),按中序遍歷右子樹。后序遍歷(LRD):按后序遍歷左子樹,按后序遍歷右子樹,訪問根結(jié)點(diǎn)。二叉樹為空時(shí),執(zhí)行空操作,即空二叉樹已遍歷完。75整理ppt〔2〕遍歷算法先序遍歷:DLR中序遍歷:LDR后序遍歷:LRDADBCT1T2T3DLRADLRDLR>B>>D>>CDLR以先序遍歷DLR為例演示遍歷過程ABDCBDACDBCA76整理ppt例題講解77整理ppt在深度為7的滿二叉樹中,葉子結(jié)點(diǎn)的個(gè)數(shù)為〔〕(2006.4)A)32 B)31C)64D)63某二叉樹有n個(gè)度為2的結(jié)點(diǎn),那么該二叉樹中的葉子節(jié)點(diǎn)數(shù)為〔〕(2007.4)A)n+1 B)n-1C)2n D)n/2具有3個(gè)結(jié)點(diǎn)的二叉樹有A)2種形態(tài)B)4種形態(tài)C)7種形態(tài)D)5種形態(tài)
78整理ppt設(shè)有以下二叉樹:
對此二叉樹前序遍歷的結(jié)果為A)ZBTTCPXA B)ATBZXCTPC)ZBTACTXPD)ATBZXCPT79整理ppt設(shè)一棵二叉樹中有3個(gè)葉子結(jié)點(diǎn),有8個(gè)度為1的結(jié)點(diǎn),那么該二叉樹中總的結(jié)點(diǎn)數(shù)為()A)12 B)13C)14 D)15設(shè)有以下二叉樹:對此二叉樹的中序遍歷的結(jié)果為A)ABCDEFB)DBEAFCC)ABDECFD)DEBFCA80整理ppt2.7查找和排序順序查找與二分查找算法根本排序算法〔交換類排序、選擇類排序、插入類排序〕81整理ppt2.7.1查找查找是在一個(gè)給定的數(shù)據(jù)結(jié)構(gòu)中,根據(jù)給定的條件查找滿足條件的結(jié)點(diǎn)。不同的數(shù)據(jù)結(jié)構(gòu)采用不同的查找方法。查找的效率直接影響數(shù)據(jù)處理的效率。查找的結(jié)果:查找成功:找到滿足條件的結(jié)點(diǎn)查找失?。赫也坏綕M足條件的結(jié)點(diǎn)。82整理ppt2.7.1.1順序查找〔線性查找〕查找過程:對給定的一關(guān)鍵字K,從線性表的一端開始,逐個(gè)進(jìn)行記錄的關(guān)鍵字和K的比較,直到找到關(guān)鍵字等于K的記錄或到達(dá)表的另一端??梢圆捎脧那跋蚝蟛?,也可采用從后向前查的方法?!ぴ谄骄闆r下,大約要與表中一半以上元素進(jìn)行比較,效率較低。平均查找長度較大?!ぴ谙旅鎯煞N情況下只能采取順序查找:a.線性表為無序表〔元素排列是無序的〕;b.即使是有序線性表,但采用的是鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)。83整理ppt2.7.1.2折半查找〔二分法查找〕思想:先確定待查找記錄所在的范圍,然后逐步縮小范圍,直到找到或確認(rèn)找不到該記錄為止。前提:必須在具有順序存儲(chǔ)結(jié)構(gòu)的有序表中進(jìn)行。分三種情況:1〕假設(shè)中間項(xiàng)的值等于x,那么說明已查到。2〕假設(shè)x小于中間項(xiàng)的值,那么在線性表的前半局部查找;3〕假設(shè)x大于中間項(xiàng)的值,那么在線性表的后半局部查找。特點(diǎn):比順序查找方法效率高。最壞的情況下,需要比較log2n次。84整理ppt查找23和79的過程如以下圖:mid=(low+high)/2不進(jìn)位取整(08,14,23,37,46,55,68,79,91)(08,14,23,37,46,55,68,79,91)lowhighmid(08,14,23,37,46,55,68,79,91)lowhigh=mid-1mid(08,14,23,37,46,55,68,79,91)low=mid+1highmid(08,14,23,37,46,55,68,79,
91)lowhighmid(08,14,23,37,46,55,68,79,91)lowhighmid(08,14,23,37,46,55,68,79,91)lowhighmid85整理ppt2.7.2排序2.7.2.1概述1、排序的功能:將一個(gè)數(shù)據(jù)元素〔或記錄〕的任意序列,重新排成一個(gè)按關(guān)鍵字有序的序列。2、排序過程的組成步驟:首先比較兩個(gè)關(guān)鍵字的大??;然后將記錄從一個(gè)位置移動(dòng)到另一個(gè)位置。86整理ppt排序方法插入排序選擇排序交換排序歸并排序直接插入排序折半插入排序簡單項(xiàng)選擇擇排序堆排序起泡排序快速排序87整理ppt2.7.2.2插入排序直接插入、折半插入1、直接插入排序:根本思想:從數(shù)組的第2號(hào)元素開始,順序從數(shù)組中取出元素,并將該元素插入到其左端已排好序的數(shù)組的適當(dāng)位置上。需要n(n-1)/2次比較88整理ppt該算法適合于n較小的情況,時(shí)間復(fù)雜度為O(n2).待排元素序列:[53]2736156942第一次排序:[2753]36156942第二次排序:[273653]156942第三次排序:[15273653]6942第四次排序:[1527365369]42第五次排序:[152736425369]
直接插入排序例如對于有n個(gè)數(shù)據(jù)元素的待排序列,插入操作要進(jìn)行n-1次89整理ppt2、折半插入排序折半插入排序在尋找插入位置時(shí),不是逐個(gè)比較而是利用折半查找的原理尋找插入位置。待排序元素越多,改進(jìn)效果越明顯。折半插入排序的條件:在有序序列中插入一個(gè)關(guān)鍵字。90整理ppt例:有6個(gè)記錄,前5個(gè)已排序的基礎(chǔ)上,對第6個(gè)記錄排序。[1527365369]42
low
mid
high
[1527365369]42
low
high
mid
[1527365369]42
high
low[152736425369](high<low,查找結(jié)束,插入位置為low或high+1)(42>36)(42<53)91整理ppt1、簡單項(xiàng)選擇擇排序思想:首先從1~n個(gè)元素中選出關(guān)鍵字最小的記錄交換到第一個(gè)位置上。然后再從第2個(gè)到第n個(gè)元素中選出次小的記錄交換到第二個(gè)位置上,依次類推。時(shí)間復(fù)雜度為O(n2),最壞情況下需要比較n(n-1)/2次適用于待排序元素較少的情況。2.7.2.3選擇排序簡單項(xiàng)選擇擇排序、堆排序92整理ppt初態(tài)83916839168391683916ijkijkijkijk1
3986互換ijk1
3
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年高速精密自動(dòng)沖床項(xiàng)目可行性研究報(bào)告
- 滾動(dòng)付款賬期合同
- 二零二五年度個(gè)人房屋買賣合同共有產(chǎn)權(quán)處理辦法3篇
- 二零二五年型汽車吊機(jī)租賃及吊裝作業(yè)指導(dǎo)書合同3篇
- 2025版勞動(dòng)合同主體變更及女職工權(quán)益保護(hù)協(xié)議書3篇
- 簡易綠化合同范本
- 內(nèi)外粉地面屋面散水合同
- 北京藝術(shù)傳媒職業(yè)學(xué)院《英語聽說三》2023-2024學(xué)年第一學(xué)期期末試卷
- 北京藝術(shù)傳媒職業(yè)學(xué)院《化學(xué)與社會(huì)(生活中的柔性光電子學(xué))》2023-2024學(xué)年第一學(xué)期期末試卷
- 二零二五年勞動(dòng)和社會(huì)保障局監(jiān)管的職工工傷賠償合同3篇
- 2023年全國中小學(xué)思政課教師網(wǎng)絡(luò)培訓(xùn)研修總結(jié)心得體會(huì)
- 老年人能力評估標(biāo)準(zhǔn)表
- 卷內(nèi)目錄及卷內(nèi)備考表
- 國開大學(xué)2023年01月11110《工程地質(zhì)》期末考試答案
- 模擬電子技術(shù)課程設(shè)計(jì)報(bào)告
- 成都市金牛區(qū)八年級(jí)上學(xué)期期末考試語文試題
- 部編版九年級(jí)語文上冊教科書(課本全冊)課后習(xí)題參考答案
- 水性建筑涂料企業(yè)風(fēng)險(xiǎn)點(diǎn)告知卡
- 涉詐風(fēng)險(xiǎn)賬戶審查表
- 水利二級(jí)建造師繼續(xù)教育試題及答案(江西)
- 天津市中小學(xué)生思想品德發(fā)展水平評價(jià)指標(biāo)(小學(xué)中高年級(jí)學(xué)段)
評論
0/150
提交評論