版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
本文格式為Word版,下載可任意編輯——數(shù)據(jù)結(jié)構(gòu)第四章知識點(diǎn)總結(jié)(5篇)總結(jié)是對過去一定時期的工作、學(xué)習(xí)或思想狀況進(jìn)行回想、分析,并做出客觀評價的書面材料,它有助于我們尋覓工作和事物發(fā)展的規(guī)律,從而把握并運(yùn)用這些規(guī)律,是時候?qū)懸环菘偨Y(jié)了。寫總結(jié)的時候需要注意什么呢?有哪些格式需要注意呢?這里給大家共享一些最新的總結(jié)書范文,便利大家學(xué)習(xí)。
數(shù)據(jù)結(jié)構(gòu)第四章知識點(diǎn)總結(jié)篇一
第一章:
知識點(diǎn):數(shù)據(jù)結(jié)構(gòu)的定義;數(shù)據(jù)元素關(guān)系的基本結(jié)構(gòu)類型;數(shù)據(jù)元素的不同存儲結(jié)構(gòu);算法的重要特性;評價算法的重要指標(biāo);如何由程序代碼估算算法的繁雜度(大o描述)。
其次章:
知識點(diǎn):線性表不同的存儲方式及其各自特點(diǎn);順序表及鏈表的基本操作(插入、刪除等)與其具體代碼實(shí)現(xiàn)。
第三章:
知識點(diǎn):棧和隊列的結(jié)構(gòu)特點(diǎn);二者基本操作的思想;鏈隊列和循環(huán)隊列的基本操作;循環(huán)隊列如何判空和判滿。
第四章:
知識點(diǎn):串的相關(guān)定義與基本操作;模式匹配的定義與思想。
第五章:
知識點(diǎn):數(shù)組的定義與順序?qū)崿F(xiàn)方式;數(shù)組順序存儲中元素地址的計算;稀疏矩陣的壓縮存儲方式與元素地址的特點(diǎn);廣義表的定義與基本操作(表頭,表尾,判長度、深度)。
第六章:
知識點(diǎn):樹的基本術(shù)語;(滿/完全)二叉樹的定義與各種性質(zhì)特點(diǎn);二叉樹不同的存儲與遍歷方式;一般樹的存儲結(jié)構(gòu);樹與森林的遍歷方式;赫夫曼樹與編碼的求法。
第七章:
知識點(diǎn):(有向/無向/完全)圖的概念與其特點(diǎn);(強(qiáng))聯(lián)通圖的定義與特點(diǎn);圖的不同存儲結(jié)構(gòu)及其操作;圖的不同方式的遍歷;最小生成樹的定義與其不同的求解方法;拓?fù)渑判虻亩x與思想;關(guān)鍵(最短)路徑的定義與思想。
第九章:
知識點(diǎn):順序查找、折半查找的思想及其具體代碼實(shí)現(xiàn)和繁雜度分析;索引查找的思想;二叉排序樹的思想及操作;平衡二叉樹的定義與操作;b-樹的定義與特點(diǎn);哈希表(函數(shù))的定義;哈希函數(shù)的構(gòu)造方法與處理沖突的方法。
第十章:
知識點(diǎn):各種排序方法的思想與其繁雜度、穩(wěn)定性分析。
注:以上涉及到的繁雜度分析,其推導(dǎo)過程不做要求。
數(shù)據(jù)結(jié)構(gòu)第四章知識點(diǎn)總結(jié)篇二
2023年自學(xué)考試《數(shù)據(jù)結(jié)構(gòu)》各章復(fù)習(xí)要點(diǎn)總結(jié)(2)2023年自學(xué)考試《數(shù)據(jù)結(jié)構(gòu)》四至六章復(fù)習(xí)要點(diǎn)總結(jié)。
第四章串
串是零個或多個字符組成的有限序列。
·空串:是指長度為零的串,也就是串中不包含任何字符(結(jié)點(diǎn))。
·空白串:指串中包含一個或多個空格字符的串。
·在一個串中任意個連續(xù)字符組成的子序列稱為該串的子串,包含子串的串就稱為主串。
·子串在主串中的序號就是指子串在主串中首次出現(xiàn)的位置。
·空串是任意串的子串,任意串是自身的子串。
串分為兩種:
·串常量在程序中只能引用不能改變;
·串變量的值可以改變。
串的基本運(yùn)算有:
·求串長strlen(char*s)
·串復(fù)制strcpy(char*to,char*from)
·串聯(lián)接strcat(char*to,char*from)
·串比較charcmp(char*s1,char*s2)
·字符定位strchr(char*s,charc)
。串是特別的線性表(結(jié)點(diǎn)是字符),所以串的存儲結(jié)構(gòu)與線性表的存儲結(jié)構(gòu)類似。串的順序存儲結(jié)構(gòu)簡稱為順序串。
順序串又可按存儲分派的不同分為:
·靜態(tài)存儲分派:直接用定長的字符數(shù)組來定義。優(yōu)點(diǎn)是涉及串長的操作速度快,但不適合插入、鏈接操作。
·動態(tài)存儲分派:是在定義串時不分派存儲空間,需要使用時按所需串的長度分派存儲單元。
串的鏈?zhǔn)酱鎯褪怯脝捂湵淼姆绞酱鎯Υ?,串的這種鏈?zhǔn)酱鎯Y(jié)構(gòu)簡稱為鏈串。鏈串與單鏈表的差異只是它的結(jié)點(diǎn)數(shù)據(jù)域?yàn)閱蝹€字符。
為了解決“存儲密度〞低的狀況,可以讓一個結(jié)點(diǎn)存儲多個字符,即結(jié)點(diǎn)的大小。
順序串上子串定位的運(yùn)算:又稱串的“模式匹配〞或“串匹配〞,是在主串中查找出子串出現(xiàn)的位置。在串匹配中,將主串稱為目標(biāo)(串),子串稱為模式(串)。這是比較簡單理解的,串匹配問題就是找出給定模式串p在給定目標(biāo)串t中首次出現(xiàn)的有效位移或者是全部有效位移。最壞的狀況下時間繁雜度是o((n-m+1)m),假使m與n同階的話則它是o(n^2)。鏈串上的子串定位運(yùn)算位移是結(jié)點(diǎn)地址而不是整數(shù)。
第五章多維數(shù)組和廣義表
數(shù)組一般用順序存儲的方式表示。存儲的方式有:
·行優(yōu)先順序,也就是把數(shù)組逐行依次排列。pascal、c
·列優(yōu)先順序,就是把數(shù)組逐列依次排列。fortran
地址的計算方法:
·按行優(yōu)先順序排列的數(shù)組:loca(ij)=loca(11)+((i-1)*n+(j-1))*d.·按列優(yōu)先順序排列的數(shù)組:loca(ij)=loca(11)+((j-1)*n+(i-1))*d.矩陣的壓縮存儲:為多個一致的非零元素分派一個存儲空間;對零元素不分派空間。
特別矩陣的概念:所謂特別矩陣是指非零元素或零元素分布有一定規(guī)律的矩陣。
稀疏矩陣的概念:一個矩陣中若其非零元素的個數(shù)遠(yuǎn)遠(yuǎn)小于零元素的個數(shù),則該矩陣稱為稀疏矩陣。
特別矩陣的類型:
·對稱矩陣:滿足a(ij)=a(ji)。元素總數(shù)n(n+1)/2.i=max(i,j),j=min(i,j),loca(ij)=loc(sa[0])+(i*(i+1)/2+j)*d.·三角矩陣:
·上三角陣:k=i*(2n-i+1)/2+j-i,loca(ij)=loc(sa[0])+k*d.·下三角陣:k=i*(i+1)/2+j,loca(ij)=loc(sa[0])+k*d.·對角矩陣:k=2i+j,loca(ij)=loc(sa[0])+k*d.稀疏矩陣的壓縮存儲方式用三元組表把非零元素的值和它所在的行號列號做為一個結(jié)點(diǎn)存放在一起,用這些結(jié)點(diǎn)組成的一個線性表來表示。但這種壓縮存儲方式將失去隨機(jī)存儲功能。參與行表記錄每行的非零元素在三元組表中的起始位置,即帶行表的三元組表。
廣義表是n(n≥0)個元素的有限序列,其中的元素是原子或者是一個廣義表。
廣義表表頭和表尾的概念:
·若廣義表ls非空(n≥1),則這個廣義表的第一個元素就是表頭。
·其余的元素組成的表稱為ls的表尾,所以表尾必是一個子表。
廣義表有兩種表示法,一種是括號表示法,一種是圖形表示法。
廣義表與樹(形結(jié)構(gòu))相對應(yīng),這個廣義表就是純表。
假使一個廣義表的結(jié)點(diǎn)又可以被其他結(jié)點(diǎn)所共享,則這個表稱為再入表。
允許遞歸的表稱為遞歸表。
線性表∈純表(樹)∈再入表∈遞歸表。可見,廣義表是對線性表和樹的推廣。
廣義表有兩個特別的基本運(yùn)算:
·取表頭head(ls):取表中的第一個數(shù)據(jù)元素,不能對空表操作。
·取表尾tail(ls);取除表頭外,其余數(shù)據(jù)元素構(gòu)成的子表,不能對空表操作。
第六章樹
樹是n個結(jié)點(diǎn)的有限集合,非空時必需滿足:只有一個稱為根的結(jié)點(diǎn);其余結(jié)點(diǎn)形成m個不相交的子集,并稱根的子樹。
根是開始結(jié)點(diǎn);結(jié)點(diǎn)的子樹數(shù)稱度;度為0的結(jié)點(diǎn)稱葉子(終端結(jié)點(diǎn));度不為0的結(jié)點(diǎn)稱分支結(jié)點(diǎn)(非終端結(jié)點(diǎn));除根外的分支結(jié)點(diǎn)稱內(nèi)部結(jié)點(diǎn);
有序樹是子樹有左,右之分的樹;無序樹是子樹沒有左,右之分的樹;森林是m個互不相交的樹的集合;
樹的四種不同表示方法:
·樹形表示法;
·嵌套集合表示法;
·凹入表示法;
·廣義表表示法。
二叉樹的定義:是n≥0個結(jié)點(diǎn)的有限集,它是空集(n=0)或由一個根結(jié)點(diǎn)及兩棵互不相交的分別稱作這個根的左子樹和右子樹的二叉樹組成。
二叉樹不是樹的特別情形,與度數(shù)為2的有序樹不同。
二叉樹的4個重要性質(zhì):
·二叉樹上第i層上的結(jié)點(diǎn)數(shù)目最多為2^(i-1)(i≥1);
·深度為k的二叉樹至多有(2^k)-1個結(jié)點(diǎn)(k≥1);
·在任意一棵二叉樹中,若終端結(jié)點(diǎn)的個數(shù)為n0,度為2的結(jié)點(diǎn)數(shù)為n2,則n0=n2+1;
·具有n個結(jié)點(diǎn)的完全二叉樹的深度為int(log2n)+1。滿二叉樹是一棵深度為k,結(jié)點(diǎn)數(shù)為(2^k)-1的二叉樹;完全二叉樹是滿二叉樹在最下層自右向左去處部分結(jié)點(diǎn);
二叉樹的順序存儲結(jié)構(gòu)就是把二叉樹的所有結(jié)點(diǎn)依照層次順序存儲到連續(xù)的存儲單元中。(存儲前先將其畫成完全二叉樹)
樹的存儲結(jié)構(gòu)多用的是鏈?zhǔn)酱鎯?。bintnode的結(jié)構(gòu)為lchild|data|rchild,把所有bintnode類型的結(jié)點(diǎn),加上一個指向根結(jié)點(diǎn)的bintree型頭指針就構(gòu)成了二叉樹的鏈?zhǔn)酱鎯Y(jié)構(gòu),稱為二叉鏈表。它就是由根指針root唯一確定的。共有2n個指針域,n+1個空指針。
根據(jù)訪問結(jié)點(diǎn)的次序不同可得三種遍歷:先序遍歷(前序遍歷或先根遍歷),中序遍歷(或中根遍歷)、后序遍歷(或后根遍歷)。時間繁雜度為o(n)。
利用二叉鏈表中的n+1個空指針域來存放指向某種遍歷次序下的前趨結(jié)點(diǎn)和后繼結(jié)點(diǎn)的指針,這些附加的指針就稱為“線索〞,加上線索的二叉鏈表就稱為線索鏈表。線索使得查找中序前趨和中序后繼變得簡單有效,但對于查找指定結(jié)點(diǎn)的前序前趨和后序后繼并沒有什么作用。
樹和森林及二叉樹的轉(zhuǎn)換是唯一對應(yīng)的。
轉(zhuǎn)換方法:
·樹變二叉樹:兄弟相連,保存長子的連線。
·二叉樹變樹:結(jié)點(diǎn)的右孩子與其雙親連。
·森林變二叉樹:樹變二叉樹,各個樹的根相連。
樹的存儲結(jié)構(gòu):
·有雙親鏈表表示法:結(jié)點(diǎn)data|parent,對于求指定結(jié)點(diǎn)的雙親或祖先十分便利,但不適于求指定結(jié)點(diǎn)的孩子及后代。
·孩子鏈表表示法:為樹中每個結(jié)點(diǎn)data|next設(shè)置一個孩子鏈表firstchild,并將data|firstchild存放在一個向量中。
·雙親孩子鏈表表示法:將雙親鏈表和孩子鏈表結(jié)合。
·孩子兄弟鏈表表示法:結(jié)點(diǎn)結(jié)構(gòu)leftmostchild|data|rightsibing,附加兩個分別指向該結(jié)點(diǎn)的最左孩子和右鄰兄弟的指針域。樹的前序遍歷與相對應(yīng)的二叉樹的前序遍歷一致;樹的后序遍歷與相對應(yīng)的二叉樹的中序遍歷一致。
樹的帶權(quán)路徑長度是樹中所有葉結(jié)點(diǎn)的帶權(quán)路徑長度之和。樹的帶權(quán)路徑長度最小的二叉樹就稱為最優(yōu)二叉樹(即哈夫曼樹)。
在葉子的權(quán)值一致的二叉樹中,完全二叉樹的路徑長度最短。
哈夫曼樹有n個葉結(jié)點(diǎn),共有2n-1個結(jié)點(diǎn),沒有度為1的結(jié)點(diǎn),這類樹又稱為嚴(yán)格二叉樹。
變長編碼技術(shù)可以使頻度高的字符編碼短,而頻度低的字符編碼長,但是變長編碼可能使解碼產(chǎn)生二義性。如00、01、0001這三個碼無法在解碼時確定是哪一個,所以要求在字符編碼時任一字符的編碼都不是其他字符編碼的前綴,這種碼稱為前綴碼(其實(shí)是非前綴碼)。
哈夫曼樹的應(yīng)用最廣泛地是在編碼技術(shù)上,它能夠簡單地求出給定字符集及其概率分布的最優(yōu)前綴碼。哈夫曼編碼的構(gòu)造很簡單,只要畫好了哈夫曼樹,按分支狀況在左路徑上寫代碼0,右路徑上寫代碼1,然后從上到下到葉結(jié)點(diǎn)的相應(yīng)路徑上的代碼的序列就是該結(jié)點(diǎn)的最優(yōu)前綴碼。
數(shù)據(jù)結(jié)構(gòu)第四章知識點(diǎn)總結(jié)篇三
2023年自學(xué)考試《數(shù)據(jù)結(jié)構(gòu)》各章復(fù)習(xí)要點(diǎn)總結(jié)(3)龍耒為你整理:
第五章多維數(shù)組和廣義表
數(shù)組一般用順序存儲的方式表示。存儲的方式有:
·行優(yōu)先順序,也就是把數(shù)組逐行依次排列。pascal、c
·列優(yōu)先順序,就是把數(shù)組逐列依次排列。fortran
地址的計算方法:
·按行優(yōu)先順序排列的數(shù)組:loca(ij)=loca(11)+((i-1)*n+(j-1))*d.·按列優(yōu)先順序排列的數(shù)組:loca(ij)=loca(11)+((j-1)*n+(i-1))*d.矩陣的壓縮存儲:為多個一致的非零元素分派一個存儲空間;對零元素不分派空間。
特別矩陣的概念:所謂特別矩陣是指非零元素或零元素分布有一定規(guī)律的矩陣。
稀疏矩陣的概念:一個矩陣中若其非零元素的個數(shù)遠(yuǎn)遠(yuǎn)小于零元素的個數(shù),則該矩陣稱為稀疏矩陣。
特別矩陣的類型:
·對稱矩陣:滿足a(ij)=a(ji)。元素總數(shù)n(n+1)/2.i=max(i,j),j=min(i,j),loca(ij)=loc(sa[0])+(i*(i+1)/2+j)*d.·三角矩陣:
·上三角陣:k=i*(2n-i+1)/2+j-i,loca(ij)=loc(sa[0])+k*d.·下三角陣:k=i*(i+1)/2+j,loca(ij)=loc(sa[0])+k*d.·對角矩陣:k=2i+j,loca(ij)=loc(sa[0])+k*d.稀疏矩陣的壓縮存儲方式用三元組表把非零元素的值和它所在的行號列號做為一個結(jié)點(diǎn)存放在一起,用這些結(jié)點(diǎn)組成的一個線性表來表示。但這種壓縮存儲方式將失去隨機(jī)存儲功能。參與行表記錄每行的非零元素在三元組表中的起始位置,即帶行表的三元組表。
廣義表是n(n≥0)個元素的有限序列,其中的元素是原子或者是一個廣義表。
廣義表表頭和表尾的概念:
·若廣義表ls非空(n≥1),則這個廣義表的第一個元素就是表頭。
·其余的元素組成的表稱為ls的表尾,所以表尾必是一個子表。
廣義表有兩種表示法,一種是括號表示法,一種是圖形表示法。
廣義表與樹(形結(jié)構(gòu))相對應(yīng),這個廣義表就是純表。
假使一個廣義表的結(jié)點(diǎn)又可以被其他結(jié)點(diǎn)所共享,則這個表稱為再入表。
允許遞歸的表稱為遞歸表。
線性表∈純表(樹)∈再入表∈遞歸表??梢?,廣義表是對線性表和樹的推廣。
廣義表有兩個特別的基本運(yùn)算:
·取表頭head(ls):取表中的第一個數(shù)據(jù)元素,不能對空表操作。
·取表尾tail(ls);取除表頭外,其余數(shù)據(jù)元素構(gòu)成的子表,不能對空表操作。
第六章樹
樹是n個結(jié)點(diǎn)的有限集合,非空時必需滿足:只有一個稱為根的結(jié)點(diǎn);其余結(jié)點(diǎn)形成m個不相交的子集,并稱根的子樹。
根是開始結(jié)點(diǎn);結(jié)點(diǎn)的子樹數(shù)稱度;度為0的結(jié)點(diǎn)稱葉子(終端結(jié)點(diǎn));度不為0的結(jié)點(diǎn)稱分支結(jié)點(diǎn)(非終端結(jié)點(diǎn));除根外的分支結(jié)點(diǎn)稱內(nèi)部結(jié)點(diǎn);
有序樹是子樹有左,右之分的樹;無序樹是子樹沒有左,右之分的樹;森林是m個互不相交的樹的集合;
樹的四種不同表示方法:
·樹形表示法;
·嵌套集合表示法;
·凹入表示法;
·廣義表表示法。
二叉樹的定義:是n≥0個結(jié)點(diǎn)的有限集,它是空集(n=0)或由一個根結(jié)點(diǎn)及兩棵互不相交的分別稱作這個根的左子樹和右子樹的二叉樹組成。
二叉樹不是樹的特別情形,與度數(shù)為2的有序樹不同。
二叉樹的4個重要性質(zhì):
·二叉樹上第i層上的結(jié)點(diǎn)數(shù)目最多為2^(i-1)(i≥1);
·深度為k的二叉樹至多有(2^k)-1個結(jié)點(diǎn)(k≥1);
·在任意一棵二叉樹中,若終端結(jié)點(diǎn)的個數(shù)為n0,度為2的結(jié)點(diǎn)數(shù)為n2,則n0=n2+1;
·具有n個結(jié)點(diǎn)的完全二叉樹的深度為int(log2n)+1。滿二叉樹是一棵深度為k,結(jié)點(diǎn)數(shù)為(2^k)-1的二叉樹;完全二叉樹是滿二叉樹在最下層自右向左去處部分結(jié)點(diǎn);
二叉樹的順序存儲結(jié)構(gòu)就是把二叉樹的所有結(jié)點(diǎn)依照層次順序存儲到連續(xù)的存儲單元中。(存儲前先將其畫成完全二叉樹)
樹的存儲結(jié)構(gòu)多用的是鏈?zhǔn)酱鎯?。bintnode的結(jié)構(gòu)為lchild|data|rchild,把所有bintnode類型的結(jié)點(diǎn),加上一個指向根結(jié)點(diǎn)的bintree型頭指針就構(gòu)成了二叉樹的鏈?zhǔn)酱鎯Y(jié)構(gòu),稱為二叉鏈表。它就是由根指針root唯一確定的。共有2n個指針域,n+1個空指針。
根據(jù)訪問結(jié)點(diǎn)的次序不同可得三種遍歷:先序遍歷(前序遍歷或先根遍歷),中序遍歷(或中根遍歷)、后序遍歷(或后根遍歷)。時間繁雜度為o(n)。
利用二叉鏈表中的n+1個空指針域來存放指向某種遍歷次序下的前趨結(jié)點(diǎn)和后繼結(jié)點(diǎn)的指針,這些附加的指針就稱為“線索〞,加上線索的二叉鏈表就稱為線索鏈表。線索使得查找中序前趨和中序后繼變得簡單有效,但對于查找指定結(jié)點(diǎn)的前序前趨和后序后繼并沒有什么作用。
樹和森林及二叉樹的轉(zhuǎn)換是唯一對應(yīng)的。
轉(zhuǎn)換方法:
·樹變二叉樹:兄弟相連,保存長子的連線。
·二叉樹變樹:結(jié)點(diǎn)的右孩子與其雙親連。
·森林變二叉樹:樹變二叉樹,各個樹的根相連。
樹的存儲結(jié)構(gòu):
·有雙親鏈表表示法:結(jié)點(diǎn)data|parent,對于求指定結(jié)點(diǎn)的雙親或祖先十分便利,但不適于求指定結(jié)點(diǎn)的孩子及后代。
·孩子鏈表表示法:為樹中每個結(jié)點(diǎn)data|next設(shè)置一個孩子鏈表firstchild,并將data|firstchild存放在一個向量中。
·雙親孩子鏈表表示法:將雙親鏈表和孩子鏈表結(jié)合。
·孩子兄弟鏈表表示法:結(jié)點(diǎn)結(jié)構(gòu)leftmostchild|data|rightsibing,附加兩個分別指向該結(jié)點(diǎn)的最左孩子和右鄰兄弟的指針域。樹的前序遍歷與相對應(yīng)的二叉樹的前序遍歷一致;樹的后序遍歷與相對應(yīng)的二叉樹的中序遍歷一致。
樹的帶權(quán)路徑長度是樹中所有葉結(jié)點(diǎn)的帶權(quán)路徑長度之和。樹的帶權(quán)路徑長度最小的二叉樹就稱為最優(yōu)二叉樹(即哈夫曼樹)。
在葉子的權(quán)值一致的二叉樹中,完全二叉樹的路徑長度最短。
哈夫曼樹有n個葉結(jié)點(diǎn),共有2n-1個結(jié)點(diǎn),沒有度為1的結(jié)點(diǎn),這類樹又稱為嚴(yán)格二叉樹。
變長編碼技術(shù)可以使頻度高的字符編碼短,而頻度低的字符編碼長,但是變長編碼可能使解碼產(chǎn)生二義性。如00、01、0001這三個碼無法在解碼時確定是哪一個,所以要求在字符編碼時任一字符的編碼都不是其他字符編碼的前綴,這種碼稱為前綴碼(其實(shí)是非前綴碼)。
哈夫曼樹的應(yīng)用最廣泛地是在編碼技術(shù)上,它能夠簡單地求出給定字符集及其概率分布的最優(yōu)前綴碼。哈夫曼編碼的構(gòu)造很簡單,只要畫好了哈夫曼樹,按分支狀況在左路徑上寫代碼0,右路徑上寫代碼1,然后從上到下到葉結(jié)點(diǎn)的相應(yīng)路徑上的代碼的序列就是該結(jié)點(diǎn)的最優(yōu)前綴碼。
數(shù)據(jù)結(jié)構(gòu)第四章知識點(diǎn)總結(jié)篇四
2023年自學(xué)考試《數(shù)據(jù)結(jié)構(gòu)》各章復(fù)習(xí)要點(diǎn)總結(jié)(5)龍耒為你整理:
第九章查找
查找的同時對表做修改操作(如插入或刪除)則相應(yīng)的表稱之為動態(tài)查找表,否則稱之為靜態(tài)查找表。
衡量查找算法效率優(yōu)劣的標(biāo)準(zhǔn)是在查找過程中對關(guān)鍵字需要執(zhí)行的平均比較次數(shù)(即平均查找長度asl)。
線性表查找的方法:
·順序查找:逐個查找,asl=(n+1)/2;
·二分查找:取中點(diǎn)int(n/2)比較,若小就比左區(qū)間,大就比右區(qū)間。用二叉判定樹表示。asl=(∑(每層結(jié)點(diǎn)數(shù)*層數(shù)))/n;·分塊查找:要求“分塊有序〞,將表分成若干塊內(nèi)部不一定有序,并抽取各塊中的最大關(guān)鍵字及其位置建立有序索引表。
二叉排序樹(bst)定義是二叉排序樹是空樹或者滿足如下性質(zhì)的二叉樹:
·若它的左子樹非空,則左子樹上所有結(jié)點(diǎn)的值均小于根結(jié)點(diǎn)的值;
·若它的右子樹非空,則右子樹上所有結(jié)點(diǎn)的值均大于根結(jié)點(diǎn)的值;
·左、右子樹本身又是一棵二叉排序樹。
二叉排序樹的插入、建立、刪除的算法平均時間性能是o(nlog2n)。
二叉排序樹的刪除操作可分三種狀況進(jìn)行處理:
·*p是葉子,則直接刪除*p,即將*p的雙親*parent中指向*p的指針域置空即可。
·*p只有一個孩子*child,此時只需將*child和*p的雙親直接連接就可刪去*p。
·*p有兩個孩子,則先將*p結(jié)點(diǎn)的中序后繼結(jié)點(diǎn)的數(shù)據(jù)到*p,刪除中序后繼結(jié)點(diǎn)。
關(guān)于b-樹(多路平衡查找樹)。它適合在磁盤等直接存取設(shè)備上組織動態(tài)的查找表,是一種外查找算法。建立的方式是從下向上拱起。散列技術(shù):將結(jié)點(diǎn)按其關(guān)鍵字的散列地址存儲到散列表的過程稱為散列。
散列函數(shù)的選擇有兩條標(biāo)準(zhǔn):簡單和均勻。
常見的散列函數(shù)構(gòu)的造方法:
·平方取中法:hash=int((x^2)0)
·除余法:表長為m,hash=x%m
·相乘取整法:hash=int(m*(x*a-int(x*a));a=0.618
·隨機(jī)數(shù)法:hash=random(x)。
處理沖突的方法:
開放定址法:一般形式為hi=(h(key)+di)%m1≤i≤m-1,開放定址法要求散列表的裝填因子α≤1。
·開放定址法類型:
·線性探查法:address=(hash(x)+i)%m;·二次探查法:address=(hash(x)+i^2)%m;
·雙重散列法:address=(hash(x)+i*hash(y))%m;
·拉鏈法:是將所有關(guān)鍵字為同義詞的結(jié)點(diǎn)鏈接在同一個單鏈表中。
·拉鏈法的優(yōu)點(diǎn):
·拉鏈法處理沖突簡單,且無堆積現(xiàn)象;
·鏈表上的結(jié)點(diǎn)空間是動態(tài)申請的適于無法確定表長的狀況;
·拉鏈法中α可以大于1,結(jié)點(diǎn)較大時其指針域可忽略,因此節(jié)省空間;
·拉鏈法構(gòu)造的散列表刪除結(jié)點(diǎn)易實(shí)現(xiàn)。
·拉鏈法也有缺點(diǎn):當(dāng)結(jié)點(diǎn)規(guī)模較小時,用拉鏈法中的指針域也要占用額外空間,還是開放定址法省空間。
第十章文件
文件是性質(zhì)一致的記錄的集合。記錄是文件中存取的基本單位,數(shù)據(jù)項是文件可使用的最小單位,數(shù)據(jù)項有時稱字段或者屬性。
文件
·規(guī)律結(jié)構(gòu)是一種線性結(jié)構(gòu)。
·操作有:檢索和維護(hù)。并有實(shí)時和批量處理兩種處理方式。
文件
·存儲結(jié)構(gòu)是指文件在外存上的組織方式。
·基本的組織方式有:順序組織、索引組織、散列組織和鏈組織。
·常用的文件組織方式:順序文件、索引文件、散列文件和多關(guān)鍵字文件。
評價一個文件組織的效率,是執(zhí)行文件操作所花費(fèi)的時間和文件組織所需的存儲空間。
檢索功能的多寡和速度的快慢,是衡量文件操作質(zhì)量的重要標(biāo)志。
順序文件是指按記錄進(jìn)入文件的先后順序存放、其規(guī)律順序和物理順序一致的文件。主關(guān)鍵字有序稱順序有序文件,否則稱順序無序文件。
一切存儲在順序存儲器(如磁帶)上的文件都只能順序文件,只能按順序查找法存取。順序文件的插入、刪除和修改只能通過復(fù)制整個文件實(shí)現(xiàn)。
索引文件的組織方式:尋常是在主文件之外建立一張索引表指明規(guī)律記錄和物理記錄之間一一對應(yīng)的關(guān)系,它和主文件一起構(gòu)成索引文件。
索引非順序文件中的索引表為稠密索引。索引順序文件中的索引表為稀疏索引。
若記錄很大使得索引表也很大時,可對索引表再建立索引,稱為查找表。是一種靜態(tài)索引。
索引順序文件常用的有兩種:
·isam索引順序存取方法:是專為磁盤存取文件設(shè)計的,采用靜態(tài)索引結(jié)構(gòu)。
·vsam虛擬存儲存取方法:采用b+樹作為動態(tài)索引結(jié)構(gòu),由索引集、順序集、數(shù)據(jù)集組成。
散列文件是利用散列存儲方式組織的文件,亦稱為直接存取文件。
散列文件
·優(yōu)點(diǎn)是:文件隨機(jī)存放,記錄不需要排序;插入刪除便利;存取速度快;不需要索引區(qū),節(jié)省存儲空間。
·缺點(diǎn)是:不能進(jìn)行順序存取,只能按關(guān)鍵字隨機(jī)存取,且詢問方式限地簡單詢問,需要重新組織文件。
多重表文件:對需要查詢的次關(guān)鍵字建立相應(yīng)的索引,對一致次關(guān)鍵字的記錄建一個鏈表并將鏈表頭指針、長度、次關(guān)鍵字作為索引表的索引項。
倒排表:次關(guān)鍵字索引表稱倒排表,主文件和倒排表構(gòu)成倒排文件。
數(shù)據(jù)結(jié)構(gòu)第四章知識點(diǎn)總結(jié)篇五
數(shù)據(jù)結(jié)構(gòu)各章復(fù)習(xí)要點(diǎn)總結(jié)
第一章概論
數(shù)據(jù)就是指能夠被計算機(jī)識別、存儲和加工處理的信息的載體。
數(shù)據(jù)元素是數(shù)據(jù)的基本單位,可以由若干個數(shù)據(jù)項組成。數(shù)據(jù)項是具有獨(dú)立含義的最小標(biāo)識單位。
數(shù)據(jù)結(jié)構(gòu)的定義:
·規(guī)律結(jié)構(gòu):從規(guī)律結(jié)構(gòu)上描述數(shù)據(jù),獨(dú)立于計算機(jī)。
·線性結(jié)構(gòu):一對一關(guān)系。
·線性結(jié)構(gòu):多對多關(guān)系。
·存儲結(jié)構(gòu):是規(guī)律結(jié)構(gòu)用計算機(jī)語言的實(shí)現(xiàn)。
·順序存儲結(jié)構(gòu):如數(shù)組。
·鏈?zhǔn)酱鎯Y(jié)構(gòu):如鏈表。
·稠密索引:每個結(jié)點(diǎn)都有索引項。
·稀疏索引:每組結(jié)點(diǎn)都有索引項。
·散列存儲結(jié)構(gòu):如散列表。
·對數(shù)據(jù)的操作:定義在規(guī)律結(jié)構(gòu)上,每種規(guī)律結(jié)構(gòu)都有一個運(yùn)算集合。
·常用的有:檢索、插入、刪除、更新、排序。
·數(shù)據(jù)類型:是一個值的集合以及在這些值上定義的一組操作的總稱。
·原子類型:由語言提供。
·結(jié)構(gòu)類型:由用戶借助于描述機(jī)制定義,是導(dǎo)出類型。
抽象數(shù)據(jù)類型adt:
·是抽象數(shù)據(jù)的組織和與之的操作。相當(dāng)于在概念層上描述問題。
·優(yōu)點(diǎn)是將數(shù)據(jù)和操作封裝在一起實(shí)現(xiàn)了信息隱蔽。
程序設(shè)計的實(shí)質(zhì)是對實(shí)際問題選擇一種好的數(shù)據(jù)結(jié)構(gòu),設(shè)計一個好的算法。算法取決于數(shù)據(jù)結(jié)構(gòu)。
算法是一個良定義的計算過程,以一個或多個值輸入,并以一個或多個值輸出。
評價算法的好壞的因素:
·算法是正確的;
·執(zhí)行算法的時間;
·執(zhí)行算法的存儲空間(主要是輔助存儲空間);
·算法易于理解、編碼、調(diào)試。
時間繁雜度:是某個算法的時間花費(fèi),它是該算法所求解問題規(guī)模n的函數(shù)。
漸近時間繁雜度:是指當(dāng)問題規(guī)模趨向無窮大時,該算法時間繁雜度的數(shù)量級。
評價一個算法的時間性能時,主要標(biāo)準(zhǔn)就是算法的漸近時間繁雜度。
算法中語句的頻度不僅與問題規(guī)模有關(guān),還與輸入實(shí)例中各元素的取值相關(guān)。
時間繁雜度按數(shù)量級遞增排列依次為:常數(shù)階o(1)、對數(shù)階o(log2n)、線性階o(n)、線性對數(shù)階o(nlog2n)、平方階o(n^2)、立方階o(n^3)、……k次方階o(n^k)、指數(shù)階o(2^n)。
空間繁雜度:是某個算法的空間花費(fèi),它是該算法所求解問題規(guī)模n的函數(shù)。
算法的時間繁雜度和空間繁雜度合稱算法繁雜度。
其次章線性表
線性表是由n≥0個數(shù)據(jù)元素組成的有限序列。n=0是空表;非空表,只能有一個開始結(jié)點(diǎn),有且只能有一個終端結(jié)點(diǎn)。
線性表上定義的基本運(yùn)算:
·構(gòu)造空表:initlist(l)
·求表長:listlength(l)
·取結(jié)點(diǎn):getnode(l,i)
·查找:locatenode(l,x)
·插入:insertlist(l,x,i)
·刪除:delete(l,i)
順序表是按線性表的規(guī)律結(jié)構(gòu)次序依次存放在一組地址連續(xù)的存儲單元中。在存儲單元中的各元素的物理位置和規(guī)律結(jié)構(gòu)中各結(jié)點(diǎn)相鄰關(guān)系是一致的。地址計算:loca(i)=loca(1)+(i-1)*d;(首地址為1)/考試大收集整理/
在順序表中實(shí)現(xiàn)的基本運(yùn)算:
·插入:平均移動結(jié)點(diǎn)次數(shù)為n/2;平均時間繁雜度均為o(n)。
·刪除:平均移動結(jié)點(diǎn)次數(shù)為(n-1)/2;平均時間繁雜度均為o(n)。
線性表的鏈?zhǔn)酱鎯Y(jié)構(gòu)中結(jié)點(diǎn)的規(guī)律次序和物理次序不一定一致,為了能正確表示結(jié)點(diǎn)間的規(guī)律關(guān)系,在存儲每個結(jié)點(diǎn)值的同時,還存儲了其后繼結(jié)點(diǎn)的地址信息(即指針或鏈)。這兩部分信息組成鏈表中的結(jié)點(diǎn)結(jié)構(gòu)。一個單鏈表由頭指針的名字來命名。
單鏈表運(yùn)算:
·建立單鏈表
·頭插法:s-next=head;head=s;生成的順序與輸入順序相反。平均時間繁雜度均為o(n)。
·尾插法:head=rear=null;if(head=null)head=s;elser-next=s;r=s;平均時間繁雜度均為o(n)
·加頭結(jié)點(diǎn)的算法:對開始結(jié)點(diǎn)的操作無需特別處理,統(tǒng)一了空表和非空表。
·查找
·按序號:與查找位置有關(guān),平均時間繁雜度均為o(n)。
·按值:與輸入實(shí)例有關(guān),平均時間繁雜度均為o(n)。
·插入運(yùn)算:p=getnode(l,i-1);s-next=p-next;p-next=s;平均時間繁雜度均為o(n)
·刪除運(yùn)算:p=getnode(l,i-1);r=p-next;p-next=r-next;free(r);平均時間繁雜度均為o(n)
單循環(huán)鏈表是一種首尾相接的單鏈表,終端結(jié)點(diǎn)的指針域指向開始結(jié)點(diǎn)或頭結(jié)點(diǎn)。鏈表終止條件是以指針等于頭指針或尾指針。
采用單循環(huán)鏈表在實(shí)用中多采用尾指針表示單循環(huán)鏈表。優(yōu)點(diǎn)是查找頭指針和尾指針的時間都是o(1),不用遍歷整個鏈表。
雙鏈表就是雙向鏈表,就是在單鏈表的每個結(jié)點(diǎn)里再增加一個指向其直接前趨的指針域prior,形成兩條不同方向的鏈。由頭指針head惟一確定。
雙鏈表也可以頭尾相鏈接構(gòu)成雙(向)循環(huán)鏈表。
雙鏈表上的插入和刪除時間繁雜度均為o(1)。
順序表和鏈表的比較:
·基于空間:
·順序表的存儲空間是靜態(tài)分派,存儲密度為1;適于線性表事先確定其大小時采用。
·鏈表的存儲空間是動態(tài)分派,存儲密度1;適于線性表長度變
溫馨提示
- 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 福建師范大學(xué)《數(shù)字信號處理應(yīng)用二》2023-2024學(xué)年第一學(xué)期期末試卷
- 福建師范大學(xué)《泥塑基礎(chǔ)》2021-2022學(xué)年第一學(xué)期期末試卷
- 機(jī)器人行業(yè)2024年三季度投融市場報告
- 福建師范大學(xué)《機(jī)械設(shè)計基礎(chǔ)》2023-2024學(xué)年第一學(xué)期期末試卷
- 電氣規(guī)范考核題
- 泛函分析課件教學(xué)課件
- 2024年天津客運(yùn)駕駛員從業(yè)資格證考試答案
- 2024年呼和浩特客運(yùn)員考試題庫及答案詳解
- 2024年湖南客運(yùn)資格證操作考試內(nèi)容
- 2024年北京客運(yùn)資格證培訓(xùn)考試題答案
- 蘇教版三年級上學(xué)期科學(xué)認(rèn)識液體課件
- 激光拼焊板簡介課件
- 五年級寫人作文課件
- 鋼絲網(wǎng)骨架塑料管安裝技術(shù)交底
- 2023綜合醫(yī)院建筑設(shè)計規(guī)范
- 2022-2023學(xué)年天津南開中學(xué)高一物理第一學(xué)期期中調(diào)研試題(含解析)
- 2021年務(wù)川仡佬族苗族自治縣輔警招聘筆試題及答案解析
- 金壇區(qū)蘇科版六年級上冊勞動《05土培吊蘭》課件
- 撓度計算模板表格(自動版)
- 委托代理協(xié)議范本(中英文)
- 天翼云-高級解決方案架構(gòu)師考前沖刺
評論
0/150
提交評論