數據結構教程(胡元義)

數據結構教程(胡元義)

《數據結構教程(胡元義)》是2015年西安電子科技大學出版社出版的圖書,作者是胡元義。

基本介紹

  • 書名:數據結構教程(胡元義)
  • 作者:胡元義
  • ISBN:978-7-5606-2890-5
  • 定價:27.2元
  • 出版社:西安電子科技大學出版社
  • 出版時間:2015-06
內容簡介,目錄,

內容簡介

本書系統地介紹了數據結構的有關內容,主要包括:線性表、棧、佇列、串、數組、廣義表、樹、圖等常用數據的邏輯結構和存儲結構,使用各種數據結構的基本操作,以及查找、排序算法等。
本書採用的算法全部用C語言描述,各章節均附有大量習題。與本書配套的《數據結構教程習題解析與算法上機實現》詳細給出了本書習題的解題思路和參考答案,對書中的所有算法和涉及算法的示例都給出了完整的C語言實現程式,並且在VC++ 6.0環境下上機通過。
本書結構清晰,既強調知識的實用性,也注重理論的完整性,化繁為簡,將理論融入具體實例中,化難為易,以達到準確、清楚地闡述相關概念和原理的目的。書中給出的例子也具有較強的實用性與連貫性。
本書可作為高等院校相關專業本科生及碩士研究生的專業教材或參考書,也可作為相關技術人員的自學用書。

目錄

第1章 緒論 1
1.1 數據結構的概念 2
1.1.1 數據與數據元素 2
1.1.2 數據結構 3
1.2 邏輯結構與存儲結構 4
1.2.1 邏輯結構 4
1.2.2 存儲結構 5
1.3 算法與算法分析 6
1.3.1 算法的定義和描述 6
1.3.2 算法分析和複雜度計算 7
習題1 8
第2章 線性表 11
2.1 線性表及其邏輯結構 11
2.1.1 線性表的定義 11
2.1.2 線性表的基本操作 12
2.2 線性表的順序存儲結構及運算實現 12
2.2.1 線性表的順序存儲——順序表 12
2.2.2 順序表上基本運算的實現 14
2.3 線性表的鏈式存儲結構及運算實現 19
2.3.1 單鍊表 19
2.3.2 單鍊表上基本運算的實現 21
2.3.3 循環鍊表 27
2.3.4 雙向鍊表 28
2.3.5 靜態鍊表 31
2.3.6 單鍊表套用示例 33
習題2 36
第3章 棧和佇列 40
3.1 棧 40
3.1.1 棧的定義及基本運算 40
3.1.2 棧的存儲結構和運算實現 41
*3.2 棧與遞歸 46
3.2.1 遞歸及其實現 46
3.2.2 遞歸調用過程分析 47
3.3 佇列 50
3.3.1 佇列的定義及基本運算 50
3.3.2 佇列的存儲結構和運算實現 51
*3.4 遞歸轉化為非遞歸的研究 56
3.4.1 漢諾塔問題遞歸解法 56
3.4.2 漢諾塔問題非遞歸解法 59
3.4.3 八皇后問題遞歸解法 62
3.4.4 八皇后問題非遞歸解法 64
習題3 66
第4章 串 70
4.1 串的概念及基本運算 70
4.1.1 串的基本概念 70
4.1.2 串的基本運算 71
4.2 串的順序存儲結構及基本運算 72
4.2.1 串的順序存儲結構 72
4.2.2 順序串的基本運算 73
4.3 串的鏈式存儲結構及基本運算 75
4.3.1 串的鏈式存儲結構 75
4.3.2 鏈串的基本運算 76
4.4 串的模式匹配 78
4.4.1 簡單模式匹配 79
4.4.2 無回溯的KMP匹配 80
*4.4.3 next函式的改進 85
習題4 86
第5章 數組與廣義表 89
5.1 數組的概念與存儲結構 89
5.1.1 數組的基本概念 89
5.1.2 數組的存儲結構 90
5.2 特殊矩陣的壓縮存儲 92
5.2.1 對稱矩陣 92
5.2.2 三角矩陣 93
5.2.3 對角矩陣 95
5.3 稀疏矩陣 96
5.3.1 稀疏矩陣的三元組表示 96
5.3.2 稀疏矩陣的十字鍊表表示 100
5.4 廣義表 104
5.4.1 廣義表的基本概念 104
5.4.2 廣義表的存儲結構 105
5.4.3 廣義表基本操作實現算法 109
習題5 114
第6章 樹與二叉樹 118
6.1 樹的基本概念 118
6.1.1 樹的概念與定義 118
6.1.2 樹的基本術語 119
6.2 二叉樹 120
6.2.1 二叉樹的定義 120
6.2.2 二叉樹的性質 121
6.2.3 二叉樹的存儲結構 123
6.3 二叉樹的遍歷 125
6.3.1 二叉樹的遍歷方法 125
6.3.2 遍歷二叉樹的遞歸算法及遍歷示例 126
6.3.3 遍歷二叉樹的非遞歸算法 129
6.3.4 二叉樹的層次遍歷算法 133
6.3.5 由遍歷序列恢復二叉樹 134
6.3.6 二叉樹遍歷的套用 136
6.4 線索二叉樹 139
6.4.1 線索二叉樹的定義及結構 139
6.4.2 線索化二叉樹 141
6.4.3 訪問線索二叉樹 143
6.5 哈夫曼樹 145
6.5.1 哈夫曼樹的基本概念及構造方法 145
6.5.2 哈夫曼算法的實現 148
6.5.3 哈夫曼編碼 150
6.6 樹和森林 153
6.6.1 樹的定義與存儲結構 153
6.6.2 樹、森林與二叉樹之間的轉換 155
6.6.3 樹和森林的遍歷 156
習題6 157
第7章 圖 162
7.1 圖的基本概念 162
7.1.1 圖的定義 162
7.1.2 圖的基本術語 163
7.2 圖的存儲結構 165
7.2.1 鄰接矩陣 166
7.2.2 鄰接表 167
*7.2.3 有向圖的十字鍊表存儲方法 170
*7.2.4 無向圖的鄰接多重表存儲方法 171
7.3 圖的遍歷 172
7.3.1 深度優先搜尋 172
7.3.2 廣度優先搜尋 175
7.3.3 圖的連通性問題 177
7.4 生成樹與最小生成樹 178
7.4.1 生成樹和生成森林 178
7.4.2 最小生成樹與構造最小生成樹的Prim算法 181
7.4.3 構造最小生成樹的Kruskal算法 185
7.5 最短路徑 188
7.5.1 從一個源點到其他各點的最短路徑 188
7.5.2 每一對頂點之間的最短路徑 192
7.6 拓撲排序和關鍵路徑 195
7.6.1 AOV網與拓撲排序 195
7.6.2 AOE網與關鍵路徑 199
習題7 204
第8章 查找 211
8.1 查找的基本概念 211
8.2 靜態查找表 212
8.2.1 順序查找 212
8.2.2 有序表的查找 213
8.3 樹表形式的動態查找表 218
8.3.1 二叉排序樹 218
8.3.2 平衡二叉樹 225
8.3.3 B樹和B+樹 231
8.4 地址映射方式下的動態查找表——哈希表 238
8.4.1 哈希表與哈希方法 238
8.4.2 哈希函式的構造方法 239
8.4.3 處理衝突的方法 241
8.4.4 哈希表的查找 243
習題8 246
第9章 排序 253
9.1 排序的基本概念 253
9.2 插入排序 254
9.2.1 直接插入排序 254
9.2.2 折半插入排序 256
9.2.3 希爾(Shell)排序 257
9.3 交換排序 259
9.3.1 冒泡排序 259
9.3.2 快速排序 261
9.4 選擇排序 264
9.4.1 直接選擇排序 264
9.4.2 堆排序 266
9.5 歸併排序 269
9.6 基數排序 274
9.6.1 多關鍵字排序 274
9.6.2 鏈式基數排序 275
*9.7 外排序簡介 278
9.8 各種內排序方法的比較 281
習題9 283
參考文獻 288

相關詞條

熱門詞條

聯絡我們