清華大學計算機系列教材:數據結構(C語言版)(附光盤)
定 價:39 元
- 作者:嚴蔚敏 ,吳偉民 著
- 出版時間:2011/11/1
- ISBN:9787302147510
- 出 版 社:清華大學出版社
- 中圖法分類:TP312C
- 頁碼:334
- 紙張:膠版紙
- 版次:1
- 開本:16K
《清華大學計算機系列教材:數據結構(C語言版)》是為“數據結構”課程編寫的教材,也可作為學習數據結構及其算法的c程序設計的參考教材。
《清華大學計算機系列教材:數據結構(C語言版)》的前半部分從抽象數據類型的角度討論各種基本類型的數據結構及其應用;后半部分主要討論查找和排序的各種實現方法及其綜合分析比較。其內容和章節(jié)編排與1992年4月出版的《清華大學計算機系列教材:數據結構(C語言版)》(第二版)基本一致,但在本書中更突出了抽象數據類型的概念。全書采用類C語言作為數據結構和算法的描述語言。
《清華大學計算機系列教材:數據結構(C語言版)》概念表述嚴謹,邏輯推理嚴密,語言精煉,用詞達意,并有配套出版的《數據結構題集》(C語言版),既便于教學,又便于自學。
本書可作為計算機類專業(yè)或信息類相關專業(yè)的本科或專科教材,也可供從事計算機工程與應用工作的科技工作者參考。
《清華大學計算機系列教材:數據結構(C語言版)》的第1章綜述數據、數據結構和抽象數據類型等基本概念;第2章至第7章從抽象數據類型的角度,分別討論線性表、棧、隊列、串、數組、廣義表、樹和二叉樹以及圖等基本類型的數據結構及其應用;第8章綜合介紹操作系統和編譯程序中涉及的動態(tài)存儲管理的基本技術;第9章至第11章討論查找和排序,除了介紹各種實現方法之外,并著重從時間上進行定性或定量的分析和比較;第12章介紹常用的文件結構。本書可作為計算機類專業(yè)或信息類相關專業(yè)的本科或?平滩。
第1章 緒論
1.1 什么是數據結構
1.2 基本概念和術語
1.3 抽象數據類型的表示與實現
1.4 算法和算法分析
1.4.1 算法
1.4.2 算法設計的要求
1.4.3 算法效率的度量
1.4.4 算法的存儲空間需求
第2章 線性表
2.1 線性表的類型定義
2.2 線性表的順序表示和實現
2.3 線性表的鏈式表示和實現
2.3.1 線性鏈表
2.3.2 循環(huán)鏈表
2.3.3 雙向鏈表
2.4 一元多項式的表示及相加
第3章 棧和隊列
3.1 棧
3.1.1 抽象數據類型棧的定義
3.1.2 棧的表示和實現
3.2 棧的應用舉例
3.2.1 數制轉換
3.2.2 括號匹配的檢驗
3.2.3 行編輯程序
3.2.4 迷宮求解
3.2.5 表達式求值
3.3 棧與遞歸的實現
3.4 隊列
3.4.1 抽象數據類型隊列的定義
3.4.2 鏈隊列--隊列的鏈式表示和實現
3.4.3 循環(huán)隊列--隊列的順序表示和實現
3.5 離散事件模擬
第4章 串
4.1 串類型的定義
4.2 串的表示和實現
4.2.1 定長順序存儲表示
4.2.2 堆分配存儲表示
4.2.3 串的塊鏈存儲表示
4.3 串的模式匹配算法
4.3.1 求子串位置的定位函數Index(S,T,pos)
4.3.2 模式匹配的一種改進算法
4.4 串操作應用舉例
4.4.1 文本編輯
4.4.2 建立詞索引表
第5章 數組和廣義表
5.1 數組的定義
5.2 數組的順序表示和實現
5.3 矩陣的壓縮存儲
5.3.1 特殊矩陣
5.3.2 稀疏矩陣
5.4 廣義表的定義
5.5 廣義表的存儲結構
5.6 m元多項式的表示
5.7 廣義表的遞歸算法
5.7.1 求廣義表的深度
5.7.2 復制廣義表
5.7.3 建立廣義表的存儲結構
第6章 樹和二叉樹
6.1 樹的定義和基本術語
6.2 二叉樹
6.2.1 二叉樹的定義
6.2.2 二叉樹的性質
6.2.3 二叉樹的存儲結構
6.3 遍歷二叉樹和線索二叉樹
6.3.1 遍歷二叉樹
6.3.2 線索二叉樹
6.4 樹和森林
6.4.1 樹的存儲結構
6.4.2 森林與二叉樹的轉換
6.4.3 樹和森林的遍歷
6.5 樹與等價問題
6.6 赫夫曼樹及其應用
6.6.1 最優(yōu)二叉樹(赫夫曼樹)
6.6.2 赫夫曼編碼
6.7 回溯法與樹的遍歷
6.8 樹的計數
第7章 圖
7.1 圖的定義和術語
7.2 圖的存儲結構
7.2.1 數組表示法
7.2.2 鄰接表
7.2.3 十字鏈表
7.2.4 鄰接多重表
7.3 圖的遍歷
7.3.1 深度優(yōu)先搜索
7.3.2 廣度優(yōu)先搜索
7.4 圖的連通性問題
7.4.1 無向圖的連通分量和生成樹
7.4.2 有向圖的強連通分量
7.4.3 最小生成樹
7.4.4 關節(jié)點和重連通分量
7.5 有向無環(huán)圖及其應用
7.5.1 拓撲排序
7.5.2 關鍵路徑
7.6 最短路徑
7.6.1 從某個源點到其余各頂點的最短路徑
7.6.2 每一對頂點之間的最短路徑
第8章 動態(tài)存儲管理
8.1 概述
8.2 可利用空間表及分配方法
8.3 邊界標識法
8.3.1 可利用空間表的結構
8.3.2 分配算法
8.3.3 回收算法
8.4 伙伴系統
8.4.1 可利用空間表的結構
8.4.2 分配算法
8.4.3 回收算法
8.5 無用單元收集
8.6 存儲緊縮
第9章 查找
9.1 靜態(tài)查找表
9.1.1 順序表的查找
9.1.2 有序表的查找
9.1.3 靜態(tài)樹表的查找
9.1.4 索引順序表的查找
9.2 動態(tài)查找表
9.2.1 二叉排序樹和平衡二叉樹
9.2.2 B樹和B+樹
9.2.3 鍵樹
9.3 哈希表
9.3.1 什么是哈希表
9.3.2 哈希函數的構造方法
9.3.3 處理沖突的方法
9.3.4 哈希表的查找及其分析
第10章 內部排序
10.1 概述
10.2 插入排序
10.2.1 直接插入排序
10.2.2 其他插入排序
10.2.3 希爾排序
10.3 快速排序
10.4 選擇排序
10.4.1 簡單選擇排序
10.4.2 樹形選擇排序
10.4.3 堆排序
10.5 歸并排序
10.6 基數排序
10.6.1 多關鍵字的排序
10.6.2 鏈式基數排序
10.7 各種內部排序方法的比較討論
第11章 外部排序
11.1 外存信息的存取
11.2 外部排序的方法
11.3 多路平衡歸并的實現
11.4 置換一選擇排序
11.5 最佳歸并樹
第12章 文件
12.1 有關文件的基本概念
12.2 順序文件
12.3 索引文件
12.4 ISAM文件和VSAM文件
12.4.1 ISAM文件
12.4.2 VSAM文件
12.5 直接存取文件(散列文件)
12.6 多關鍵字文件
12.6.1 多重表文件
12.6.2 倒排文件
附錄A 名詞索引
附錄B 函數索引
參考書目