全書共分8章。第1章是介紹數(shù)據(jù)結(jié)構(gòu)和算法的基本概念和算法分析的簡單方法, 以及C語言編程的要點。第2章~ 第8章對應(yīng)到數(shù)據(jù)結(jié)構(gòu)課程的7組知識單元, 包括線性表, 棧和隊列, 數(shù)組、字符串和廣義表, 樹、二叉樹與森林, 圖, 查找, 排序, 并做了適當(dāng)延伸。
(1)根據(jù)教育部頒發(fā)的《高等學(xué)校計算機科學(xué)與技術(shù)專業(yè)公共核心知識體系與課程》規(guī)范編寫。
(2)內(nèi)容涵蓋數(shù)據(jù)結(jié)構(gòu)與算法的基本概念和算法分析的簡單方法,以及C語言編程的要點。
(3)作者在討論每一個知識單元時,結(jié)合30多年教學(xué)的經(jīng)驗和考試輔導(dǎo)的體會,合理安排了教材內(nèi)容,力求透徹、全面。對學(xué)生讀書容易忽略的地方和隱藏在書中所討論問題后面的東西,都有適當(dāng)?shù)奶崾尽?
。4)是學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)與算法課程的教材,也可以作為計算機專業(yè)考研的輔導(dǎo)教材或其他計算機或軟件考試的復(fù)習(xí)教材。
第2版前言
本書第2版的初稿完成于2015年12月,作為另一本教材《數(shù)據(jù)結(jié)構(gòu)精講與習(xí)題詳解》(第2版)的寫作參照,相互融合,相互補充,首先完成了該書,再回過頭來第二次修改本書,所以本書實際上是第2版的修訂本。
自從1978年美籍華人冀中田*次在中國講授“數(shù)據(jù)結(jié)構(gòu)”課開始,很多老師對課程的內(nèi)容和講授方法做了大量的研究,也可以說是在做中學(xué),總結(jié)出許多好的經(jīng)驗,使得課程的教學(xué)比當(dāng)時進步了很多。我本人在這門課程的教學(xué)中也積累了一些心得,非常希望與正在學(xué)習(xí)這門課程的同學(xué)們分享,這是我修改這本教材的初衷。
既然數(shù)據(jù)結(jié)構(gòu)與算法相輔相成,密不可分,而算法就是解決問題的過程描述,那么,描述數(shù)據(jù)結(jié)構(gòu)與算法的語言就應(yīng)該是過程性的。早期用偽代碼描述,實踐證明不可持續(xù),因為很多用偽代碼描述的算法轉(zhuǎn)換為使用某種編程語言編寫的程序后,怎么也通不過。原因是很多人編程語言的實踐能力太差,算法的實現(xiàn)細節(jié)太粗糙。所以我認為,使用某種過程性語言,如C、C++等,對于學(xué)習(xí)和實現(xiàn)數(shù)據(jù)結(jié)構(gòu)與算法是合適的。
由于數(shù)據(jù)結(jié)構(gòu)課程學(xué)時的限制(多數(shù)學(xué)校為48~64學(xué)時),作為本科生的教材,包含的知識容量應(yīng)有一定限度。知識點太少,學(xué)生在未來的學(xué)習(xí)和工作中可聯(lián)想的思考空間狹窄,使解決問題的能力受限;知識點太多,必然淪為百科全書式的閱讀,基礎(chǔ)不牢靠,同樣使得解決問題的能力受限。通過教學(xué)實踐證明,本書的第1版在內(nèi)容上取材是恰當(dāng)?shù),范圍上取材的深度和廣度也是恰當(dāng)?shù),但?lián)想不夠,某些算法的實現(xiàn)上偏向使用偽代碼描述,造成部分讀者在學(xué)習(xí)上和實踐上的困惑。本書第2版修改部分包括:
(1)在結(jié)構(gòu)上從第1版的10章改為8章,雖然章數(shù)壓縮了,但敘述內(nèi)容不減反增。增加的知識點大多作為“擴展閱讀”出現(xiàn),它們不作為考核內(nèi)容,主要是拓展視野。
(2)各章的“想想看”改為“思考題”,目的是增加一些互動環(huán)節(jié)。這些思考題觸及的都是可聯(lián)想的內(nèi)容,或者是對理解正文有用的知識“點撥”。所謂“學(xué)問”就是有“學(xué)”還要有“問”。正面的“問”有助于理解“應(yīng)該做什么”,反面的“問”有助于理解“不該做什么”。
(3)書中所有使用C語言書寫的算法,包括輔助教材《數(shù)據(jù)結(jié)構(gòu)精講與習(xí)題詳解》(第2版)中的800道算法題,都重新使用VC++ 6.0編譯程序調(diào)試過,有的還按照軟件工程的要求做了邊界值測試。因為書中算法的正確運行需要構(gòu)建運行環(huán)境,所以對于書中所涉及的主要數(shù)據(jù)結(jié)構(gòu)的存儲表示,絕大多數(shù)都在第2版給出了結(jié)構(gòu)定義、初始化或創(chuàng)建算法、輸出算法等,這樣可由讀者自行搭建運行環(huán)境。
。4)第3章增加了多棧共享同一存儲時的棧浮動技術(shù)、遞歸程序的非遞歸模擬方法、優(yōu)先隊列的內(nèi)容;第4章增加了w對角矩陣的壓縮存儲、稀疏矩陣的鏈表存儲、串的BM模式匹配算法的內(nèi)容;第5章增加了等價類與并查集的內(nèi)容;第6章增加了構(gòu)造*小生成樹的破圈法、Dijkstra算法的內(nèi)容;第7章增加了跳表、紅黑樹、伸展樹、字典樹的內(nèi)容。此外對保留的內(nèi)容有部分增刪。教材現(xiàn)有內(nèi)容基本覆蓋大多數(shù)學(xué)校的教學(xué)大綱和考研大綱。
。5)附錄增加了詞匯索引,書中出現(xiàn)的重要概念都收錄在索引中,大大方便了讀者查閱相關(guān)的詞匯。
各章所附習(xí)題不包括選擇題,但精選了許多綜合應(yīng)用題,這些習(xí)題的參考解答請參看作者的另一本配套教材《數(shù)據(jù)結(jié)構(gòu)精講與習(xí)題詳解》。
因為作者的水平有限,可能在某些方面有考慮不周的地方,書中難免存在疏漏或錯誤,誠懇希望讀者提出寶貴意見。
作 者
2016年8月于清華大學(xué)
收起全部↑
第1章 緒論 1
1.1 數(shù)據(jù)結(jié)構(gòu)的概念及分類 1
1.1.1 為什么要學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu) 1
1.1.2 與數(shù)據(jù)結(jié)構(gòu)相關(guān)的基本術(shù)語 2
1.1.3 數(shù)據(jù)結(jié)構(gòu)的分類 5
1.1.4 數(shù)據(jù)結(jié)構(gòu)的存儲結(jié)構(gòu) 6
1.1.5 定義在數(shù)據(jù)結(jié)構(gòu)上的操作 7
1.1.6 “好”數(shù)據(jù)結(jié)構(gòu) 7
1.2 使用C語言描述數(shù)據(jù)結(jié)構(gòu) 7
1.2.1 C語言的數(shù)據(jù)類型 8
1.2.2 算法的控制結(jié)構(gòu) 9
1.2.3 算法的函數(shù)結(jié)構(gòu) 10
1.2.4 動態(tài)存儲分配 12
1.2.5 邏輯和關(guān)系運算的約定 12
1.2.6 輸入與輸出 13
1.3 算法和算法設(shè)計 13
1.3.1 算法的定義和特性 13
1.3.2 算法的設(shè)計步驟 14
1.3.3 算法設(shè)計的基本方法 15
1.4 算法分析與度量 18
1.4.1 算法的評價標準 18
1.4.2 算法的時間和空間復(fù)雜度度量 18
1.4.3 算法的漸近分析 21
小結(jié) 24
習(xí)題 24
第2章 線性表 27
2.1 線性表 27
2.1.1 線性表的定義和特點 27
2.1.2 線性表的主要操作 28
2.2 順序表 29
2.2.1 順序表的定義和特點 29
2.2.2 順序表的結(jié)構(gòu)定義 30
2.2.3 順序表查找操作的實現(xiàn) 31
2.2.4 順序表插入和刪除操作的實現(xiàn) 32
2.2.5 順序表的應(yīng)用:集合運算 34
2.3 單鏈表 35
2.3.1 單鏈表的定義和特點 35
2.3.2 單鏈表的結(jié)構(gòu)定義 36
2.3.3 單鏈表中的插入與刪除 36
2.3.4 帶頭結(jié)點的單鏈表 40
2.3.5 單鏈表的遍歷與創(chuàng)建 42
2.3.6 單鏈表的應(yīng)用:集合運算 44
2.3.7 循環(huán)鏈表 46
2.3.8 雙向鏈表 50
2.3.9 靜態(tài)鏈表 53
2.4 順序表與線性鏈表的比較 54
2.5 線性表的應(yīng)用:一元多項式及其運算 56
2.5.1 一元多項式的表示 56
2.5.2 多項式的結(jié)構(gòu)定義 57
2.5.3 多項式的加法 59
2.5.4 擴展閱讀:多項式的乘法 60
小結(jié) 62
習(xí)題 63
第3章 棧和隊列 66
3.1 棧 66
3.1.1 棧的概念 66
3.1.2 順序棧 67
3.1.3 擴展閱讀:多棧處理 70
3.1.4 鏈式棧 73
3.1.5 擴展閱讀:棧的混洗 74
3.2 隊列 76
3.2.1 隊列的概念 76
3.2.2 循環(huán)隊列 76
3.2.3 鏈式隊列 80
3.3 棧的應(yīng)用 82
3.3.1 數(shù)制轉(zhuǎn)換 82
3.3.2 括號匹配 83
3.3.3 表達式的計算與優(yōu)先級處理 84
3.3.4 棧與遞歸的實現(xiàn) 88
3.4 隊列的應(yīng)用 91
3.5 在算法設(shè)計中使用遞歸 92
3.5.1 漢諾塔問題與分治法 92
3.5.2 直接把遞歸過程改為非遞歸過程 94
3.5.3 擴展閱讀:遞歸過程的非遞歸模擬算法 95
3.5.4 迷宮問題與回溯法 98
3.5.5 計算組合數(shù)與動態(tài)規(guī)劃 101
3.6 擴展閱讀:雙端隊列 102
3.6.1 雙端隊列的概念 102
3.6.2 輸入受限的雙端隊列 103
3.6.3 輸出受限的雙端隊列 104
3.6.4 雙端隊列的存儲表示 104
3.7 擴展閱讀:優(yōu)先隊列 106
3.7.1 優(yōu)先隊列的概念 106
3.7.2 優(yōu)先隊列的實現(xiàn) 107
小結(jié) 108
習(xí)題 108
第4章 數(shù)組、串和廣義表 112
4.1 數(shù)組 112
4.1.1 一維數(shù)組 112
4.1.2 多維數(shù)組 114
4.2 特殊矩陣的壓縮存儲 116
4.2.1 對稱矩陣的壓縮存儲 117
4.2.2 三對角矩陣的壓縮存儲 118
4.2.3 擴展閱讀:w對角矩陣的壓縮存儲 119
4.3 稀疏矩陣 120
4.3.1 稀疏矩陣的概念 120
4.3.2 稀疏矩陣的順序存儲表示 121
4.3.3 稀疏矩陣的鏈表表示 124
4.4 字符串 125
4.4.1 字符串的概念 126
4.4.2 字符串的初始化和賦值 126
4.4.3 自定義字符串的存儲表示 128
4.4.4 串的模式匹配 132
4.5 廣義表 140
4.5.1 廣義表的概念 140
4.5.2 廣義表的性質(zhì) 141
4.5.3 廣義表的鏈接表示 141
4.5.4 擴展閱讀:三元多項式的表示 147