內容簡介
本書以數據的邏輯結構為線索,介紹數據結構及其建立在數據結構之上的操作和算法,內容涉及數據結構與算法的基本概念、順序存儲結構的線性表、鏈式存儲結構的線性表、串、數組、特殊矩陣與廣義表、樹與二叉樹、圖及其套用、查找與搜尋引擎、排序等。
本書既強調“算法”與“數據結構”之間緊密的依賴關係,也注重算法描述的簡潔與幹練;既有完整的理論體系,也有很好的套用案例。為了增強可理解性,本書案例與生活實踐相聯繫。
本書以知識單元為基本構件,既可拆卸也可重組,內容豐富,表述詳盡,可讀性強,適合不同類型的本科院校按照不同的培養規格組織教學。
圖書目錄
目 錄
第1章 數據結構與算法概述 1
1.1 引言 1
1.1.1 《數據結構與算法》課程到底研究什麼 1
1.1.2 《數據結構與算法》課程介紹 1
1.1.3 為什麼要學習《數據結構與算法》課程 2
1.2 基本概念和術語 3
1.2.1 數據 3
1.2.2 數據項 3
1.2.3 數據元素 4
1.2.4 數據對象 4
1.2.5 數據結構 4
1.2.6 數據結構的形式化描述 6
1.2.7 數據的邏輯結構、存儲結構與物理結構 7
1.2.8 數據結構實例 7
1.3 算法 9
1.3.1 什麼是算法 9
1.3.2 算法的性質 11
1.3.3 算法和程式 12
1.4 算法的表示(描述) 14
1.4.1 自然語言 14
1.4.2 計算機語言 15
1.4.3 圖形化工具 16
1.4.4 偽代碼 17
1.5 算法設計的準則 19
1.5.1 正確性 19
1.5.2 可讀性 20
1.5.3 健壯性 20
1.5.4 效率 21
1.6 算法效率分析 24
1.6.1 事後統計的方法 25
1.6.2 事前分析估算的方法 25
1.6.3 算法的空間複雜度 28
1.7 抽象數據類型 30
閱讀材料 32
習題1 35
第2章 順序存儲結構的線性表 39
2.1 基本概念和操作 39
2.1.1 什麼是線性表 39
2.1.2 線性表的邏輯結構 40
2.1.3 線性表的基本操作 40
2.1.4 線性表的順序存儲結構 41
2.1.5 線性表的插入與刪除操作(算法) 42
2.1.6 順序表套用舉例 45
2.2 堆疊 47
2.2.1 堆疊的定義 47
2.2.2 棧的順序存儲結構與操作(算法) 48
2.2.3 堆疊在算法設計中的套用 51
2.3 佇列 63
2.3.1 佇列的定義 64
2.3.2 佇列的順序存儲結構與操作(算法) 64
2.3.3 循環佇列 66
2.3.4 佇列套用舉例 68
2.4 集合及其運算 71
2.4.1 集合的定義 71
2.4.2 集合運算 72
2.4.3 集合的順序存儲結構和操作實現 72
小結 75
習題2 75
第3章 鏈式存儲結構的線性表 79
3.1 什麼是鏈式存儲結構的線性表 79
3.2 線性鍊表的操作(算法) 82
3.2.1 線性鍊表的構造 83
3.2.2 求表長 86
3.2.3 查找操作 86
3.2.4 線性鍊表的插入 87
3.2.5 線性鍊表的刪除 89
3.3 棧的鏈式存儲結構 90
3.4 佇列的鏈式存儲結構 92
3.5 循環鍊表 93
3.6 雙向鍊表 94
3.7 靜態鍊表 95
3.8 鍊表套用 97
3.9 一元多項式的存儲和相加 100
3.10 集合的鏈式存儲結構與操作 103
3.11 順序表和鍊表的比較 106
習題3 107
第4章 串 110
4.1 基本概念 111
4.2 串的存儲結構 112
4.2.1 順序存儲結構 112
4.2.2 鏈式存儲結構 113
4.3 串的基本操作 113
4.3.1 串複製 114
4.3.2 求字元串的長度 115
4.3.3 字元串連線 115
4.3.4 取子串 115
4.3.5 判斷兩個字元串是否相等 116
4.3.6 插入字元串 117
4.3.7 刪除子串 117
4.3.8 字元串清空 118
4.3.9 判斷字元串是否為空 118
4.3.10 字元串比較 118
4.4 串的模式匹配算法 119
4.4.1 模式匹配及其BF算法 119
4.4.2 模式匹配的一種改進算法——KMP算法 120
4.4.3 其他模式匹配算法 124
4.5 串操作套用舉例 132
習題4 133
第5章 數組、特殊矩陣與廣義表 136
5.1 數組的定義和運算 136
5.1.1 數組的基本概念 136
5.1.2 數組的特點 137
5.2 數組的順序存儲結構 137
5.2.1 一維數組 137
5.2.2 二維數組 138
5.2.3 三維數組 138
5.2.4 n維數組 139
5.3 特殊矩陣的壓縮存儲與處理 141
5.3.1 基本原則 141
5.3.2 對稱矩陣的壓縮存儲 141
5.3.3 三角矩陣的壓縮存儲 142
5.3.4 對角矩陣(帶狀矩陣)的壓縮存儲 143
5.4 稀疏矩陣 144
5.4.1 稀疏矩陣的三元組表存儲 145
5.4.2 稀疏矩陣的轉置 145
5.4.3 稀疏矩陣的快速轉置算法 147
5.5.4 稀疏矩陣的乘積 148
5.4.5 稀疏矩陣的十字鍊表存儲 151
5.5 廣義表 155
5.5.1 廣義表的定義 155
5.5.2 廣義表的特性 156
5.5.3 廣義表的基本操作 156
5.5.4 廣義表的存儲 157
5.5.5 廣義表的基本操作 159
習題5 162
第6章 樹與二叉樹 166
6.1 基本概念 166
6.1.1 什麼是樹 166
6.1.2 基本概念和術語 167
6.1.3 樹的表示方法 167
6.1.4 樹的基本操作 168
6.1.5 樹的存儲結構 168
6.2 二叉樹 173
6.2.1 二叉樹的定義 173
6.2.2 二叉樹的基本形態 173
6.2.3 兩種特殊的二叉樹 174
6.2.4 二叉樹具有的重要性質 175
6.2.5 二叉樹的存儲結構 176
6.2.6 二叉樹的基本操作 179
6.3 二叉樹的遍歷 179
6.3.1 二叉樹的遍歷 179
6.3.2 先序遍歷算法 180
6.3.3 中序遍歷 181
6.3.4 後序遍歷 182
6.3.5 按層次順序遍歷二叉樹 183
6.3.6 遍歷算法的套用 184
6.4 二叉樹其他運算 185
6.4.1 建造二叉樹算法 185
7.3.1 深度優先搜尋 237
7.3.2 廣度優先搜尋 239
7.3.3 搜尋算法在搜尋引擎中的套用 242
7.4 圖的連通性 243
7.4.1 無向圖的連通性 243
7.4.2 有向圖的連通性 244
7.4.3 生成樹和生成森林 245
7.4.4 關結點和重連通分量 245
7.5 最小生成樹 248
7.5.1 什麼是生成樹 248
7.5.2 構造最小生成樹的普里姆(Prim)算法 248
7.5.3 構造最小生成樹的Kruskal算法 252
7.6 最短路徑 255
7.6.1 求某一個源點到其他頂點的最短路徑 256
7.6.2 Bellman-Ford算法 259
7.6.3 每對頂點之間的最短路徑 262
7.7 有向無環圖及其套用 267
7.7.1 有向無環圖的概念 267
7.7.2 AOV網與拓撲排序 268
7.7.3 AOE網與關鍵路徑 272
習題7 277
第8章 查找與搜尋引擎 281
8.1 基本概念與術語 281
8.2 順序查找 283
8.3 二分查找(折半查找) 285
8.3.1 二分查找的定義 285
8.3.2 二分查找算法 286
8.3.3 二分查找判定樹 287
8.3.4 二分查找性能分析 287
8.4 有序表的插值查找和斐波那契查找 288
8.4.1 插值查找 288
8.4.2 斐波那契查找 288
8.5 分塊查找 289
8.6 B-樹和B+樹上的查找 291
8.6.1 B-樹及其查找 291
8.6.2 B+樹 293
8.7 哈希表與散列查找 294
8.7.1 散列的概念 295
8.7.2 哈希函式 295
8.7.3 散列存儲的衝突 298
8.7.4 裝填因子 298
8.7.5 衝突解決方法 298
8.7.6 散列存儲的平均查找長度 302
8.7.7 散列存儲的優缺點 303
8.8 搜尋引擎及其相關技術 303
8.8.1 網頁的自動下載與存儲 304
8.8.2 網頁索引技術 306