數據結構與算法——C語言版

傳智播客

  • 出版商: 清華大學
  • 出版日期: 2016-09-01
  • 定價: $294
  • 售價: 8.5$250
  • 語言: 簡體中文
  • 頁數: 366
  • 裝訂: 平裝
  • ISBN: 7302440689
  • ISBN-13: 9787302440680
  • 相關分類: C 程式語言
  • 下單後立即進貨 (約4週~6週)

  • 數據結構與算法——C語言版-preview-1
  • 數據結構與算法——C語言版-preview-2
  • 數據結構與算法——C語言版-preview-3
數據結構與算法——C語言版-preview-1

商品描述

本書以C語言為基礎講解數據結構與算法。全書共11章,全面介紹了開發中常用的數據結構,包括線性表(順序表、單鏈表、雙鏈表、循環鏈表)、棧和隊列、串、數組和廣義表、樹、圖,詳細講解了各種數據結構的實現及常用操作,以及多種查找算法、內部排序算法的原理和實現,簡要介紹了文件的相關知識,最後通過一個綜合項目對書中介紹的知識進行整合應用,幫助讀者瞭解實際項目開發的流程。 本書對每種數據結構和算法的剖析都遵循由淺入深的原則,並配以實用的案例和圖示,適合具有C語言基礎的數據結構初學者,實用性強。本書可作為高等院校電腦相關專業數據結構課程的教學參考用書,也可作為培訓教材和自學者的學慣用書。

目錄大綱

第1章數據結構與算法概述1
1.1數據結構1
1.1.1什麼是數據結構1
1.1.2數據結構的分類2
1.2抽像數據類型6
1.3算法7
1.3.1什麼是算法7
1.3.2算法的特性9
1.3.3算法的複雜度10
1.3.4算法與數據結構12
1.4小結12
【思考題】12

第2章線性表13
2.1什麼是線性表13
2.2線性表的順序存儲(順序表)14
2.2.1順序存儲的原理14
2.2.2順序存儲的實現15
2.3線性表的鍊式存儲(鍊錶)23
2.3.1鍊式存儲的原理23
2.3.2鍊式存儲的實現24
2.4雙鍊錶31
2.4.1什麼是雙鍊錶32
2.4.2雙鍊錶的實現32
2.5循環鍊錶39
2.5.1什麼是循環鍊錶39
2.5.2循環鍊錶的實現40
2.5.3約瑟夫環43
2.6本章小結48
【思考題】49

第3章棧和隊列50
3.1什麼是棧50
3.2棧的實現51
3.2.1棧的順序存儲實現51
3.2.2棧的鍊式存儲實現56
3.3棧的應用60
3.3.1用棧實現四則運算60
3.3.2棧的遞歸應用72
3.4什麼是隊列75
3.5隊列的實現75
3.5.1順序隊列的實現76
3.5.2鍊式隊列的實現80
3.5.3循環隊列84
3.6本章小結86
【思考題】87

第4章串88
4.1什麼是串88
4.2串的存儲結構89
4.2.1串的順序存儲89
4.2.2串的鍊式存儲97
4.3串的模式匹配算法98
4.3.1樸素的模式匹配98
4.3.2KMP算法(無回溯的模式匹配)101
4.4本章小結105
【思考題】105

第5章數組和廣義表106
5.1數組106
5.2矩陣的壓縮存儲109
5.2.1特殊矩陣109
5.2.2稀疏矩陣的定義110
5.2.3稀疏矩陣的創建112
5.2.4稀疏矩陣的轉置114
5.2.5稀疏矩陣的十字鍊錶表示118
5.3廣義表123
5.3.1廣義表的定義123
5.3.2廣義表的存儲結構124
5.3.3廣義表的遞歸運算125
5.4本章小結132
【思考題】132

第6章樹133
6.1樹133
6.1.1什麼是樹133
6.1.2樹的表示法135
6.2二叉樹138
6.2.1什麼是二叉樹138
6.2.2二叉樹的分類138
6.2.3二叉樹的性質139
6.3二叉樹的存儲結構141
6.3.1二叉樹的順序存儲141
6.3.2二叉樹的鍊式存儲143
6.4二叉樹的遍歷147
6.4.1二叉樹的遍歷147
6.4.2遞歸思想的應用151
6.5二叉樹的非遞歸遍歷154
6.6二叉樹與樹、森林之間的轉換162
6.6.1二叉樹與樹之間的轉換162
6.6.2二叉樹與森林之間的轉換162
6.7二叉樹的創建164
6.7.1中序和先序創建二叉樹164
6.7.2#號法創建樹166
6.8線索二叉樹169
6.8.1什麼是線索二叉樹169
6.8.2二叉樹的線索化171
6.8.3線索化二叉樹的遍歷175
6.9赫夫曼樹177
6.9.1什麼是赫夫曼樹177
6.9.2赫夫曼樹的構造178
6.9.3赫夫曼編碼179
6.10本章小結180
【思考題】181

第7章圖182
7.1圖的基本概念182
7.1.1圖的定義與基本術語182
7.1.2圖的基本操作185
7.2圖的存儲結構186
7.2.1圖的鄰接矩陣存儲187
7.2.2圖的鄰接表存儲189
7.2.3圖的十字鍊錶存儲192
7.2.4圖的鄰接多重表存儲194
7.3圖的遍歷196
7.3.1深度優先遍歷196
7.3.2廣度優先遍歷198
7.4最小生成樹201
7.4.1什麼是最小生成樹201
7.4.2Prim算法203
7.4.3Kruskal算法207
7.5最短路徑210
7.5.1從源點到其他頂點的最短路徑211
7.5.2每對頂點的最短路徑216
7.6拓撲排序219
7.7關鍵路徑224
7.8本章小結229
【思考題】230

第8章查找231
8.1查找概述231
8.2順序表的查找232
8.3有序表的查找233
8.3.1折半查找233
8.3.2插值查找235
8.3.3斐波納契查找235
8.4索引順序查找239
8.5二叉排序樹241
8.6平衡二叉樹246
8.6.1平衡二叉樹的概念246
8.6.2平衡二叉樹的插入247
8.6.3平衡二叉樹的刪除252
8.7B樹254
8.7.1B樹的概念254
8.7.2B樹的插入256
8.7.3B樹的刪除258
8.8鍵樹261
8.9哈希表265
8.9.1什麼是哈希表265
8.9.2哈希函數的構造方法267
8.9.3處理哈希衝突269
8.9.4哈希表的查找實現273
8.10本章小結275
【思考題】275

第9章內部排序276
9.1排序的概念與分類276
9.2交換排序278
9.2.1冒泡排序279
9.2.2快速排序283
9.3插入排序286
9.3.1直接插入排序286
9.3.2折半插入排序289
9.3.3希爾排序290
9.4選擇排序294
9.4.1簡單選擇排序294
9.4.2樹形選擇排序296
9.4.3堆排序298
9.5歸併排序303
9.6基數排序307
9.6.1基數排序基礎307
9.6.2鍊式基數排序310
9.7內部排序方法比較314
9.8磁盤排序315
9.8.1外部存儲設備315
9.8.2磁盤排序分析317
9.8.3置換選擇排序319
9.8.4多路平衡歸併321
9.8.5最佳歸併樹324
9.9本章小結325
【思考題】326

第10章文件327
10.1文件概述327
10.2順序文件和索引文件328
10.2.1順序文件328
10.2.2索引文件329
10.3ISAM文件和VSAM文件331
10.3.1ISAM文件331
10.3.2VSAM文件334
10.4哈希文件336
10.5多關鍵字文件337
10.5.1多重表文件337
10.5.2倒排文件338
10.6本章小結339
【思考題】339

第11章綜合項目——貪吃蛇340
11.1項目分析340
11.1.1模塊設計340
11.1.2模塊描述342
11.1.3項目分析345
11.2項目實現346
11.2.1創建項目346
11.2.2項目設計346
11.2.3項目實現349
11.2.4主函數實現360
11.2.5效果展示364
11.3項目心得365
【思考題】366