当前位置:首页 > 工业技术
实用数据结构教程  第2版
实用数据结构教程  第2版

实用数据结构教程 第2版PDF电子书下载

工业技术

  • 电子书积分:12 积分如何计算积分?
  • 作 者:颜辉,范丽梅主编;潘冠宇,刘磊,吴大亲,胡海燕,汤赫男副主编
  • 出 版 社:北京:清华大学出版社
  • 出版年份:2016
  • ISBN:9787302427445
  • 页数:317 页
图书介绍:本书共分十章,系统地介绍了各种典型的数据结构,主要包括绪论、线性表、栈和队列、串、数组和广义表、树、图、查找、排序和文件。理论知识的阐述由浅入深、语言通俗易懂,理论联系实际,强调应用能力的培养;在结构安排上,每章均以结构图形式系统地归纳和总结知识要点,配有应用案例、综合练习等内容,便于学生理解与掌握。
《实用数据结构教程 第2版》目录

第1章 绪论 1

1.1 数据结构概论 1

1.1.1 数据结构的研究对象 1

1.1.2 数据结构的基本概念 3

1.1.3 数据结构的研究内容 4

1.2 算法 6

1.2.1 算法的概念 6

1.2.2 算法的特征 7

1.2.3 算法的描述 7

1.2.4 算法分析及评价 7

1.3 C/C++ 9

1.3.1 C/C++中常用的数据类型 10

1.3.2 C/C++语句 14

小结 15

重点、难点例题解析 16

综合练习 17

第2章 线性表 20

2.1 线性表及其逻辑结构 20

2.1.1 线性表的定义 20

2.1.2 线性表的逻辑特征 21

2.2 线性表的顺序存储结构 21

2.2.1 线性表的顺序存储结构——顺序表 21

2.2.2 顺序表基本运算的实现 22

2.3 线性表的链式存储结构 26

2.3.1 线性表的链式存储结构——链表 26

2.3.2 单链表基本运算的实现 27

2.3.3 顺序存储和链式存储的比较 32

2.3.4 双链表 33

2.3.5 循环链表 35

2.3.6 静态链表 35

2.4 线性表的应用案例 36

小结 38

重点、难点例题解析 38

综合练习 42

第3章 栈和队列 45

3.1 栈 45

3.1.1 栈的定义及操作特性 45

3.1.2 栈的顺序存储结构及其基本运算的实现 46

3.1.3 栈的链式存储结构及其基本运算的实现 49

3.1.4 栈的应用举例 52

3.2 队列 58

3.2.1 队列的定义及操作特性 58

3.2.2 队列的顺序存储结构及其基本运算的实现 59

3.2.3 队列的链式存储结构及其基本运算的实现 62

3.2.4 队列的应用举例 65

3.3 栈和队列的应用案例 66

小结 68

重点、难点例题解析 68

综合练习 70

第4章 串 72

4.1 串的定义及基本概念 72

4.1.1 串的定义 72

4.1.2 串的基本运算 73

4.1.3 串的存储结构 74

4.2 串的顺序存储结构 74

4.2.1 顺序串的定义 74

4.2.2 顺序串的基本运算 74

4.3 串的链式存储结构——链串 80

4.3.1 链串的定义 80

4.3.2 链串的基本运算 81

4.4 堆 85

4.4.1 堆的定义 85

4.4.2 串的堆存储算法 86

4.5 串的模式匹配算法 87

4.5.1 Brute-Force算法 87

4.5.2 KMP算法 88

4.5.3 next数组及nextval数组 91

4.6 串的应用案例 92

小结 97

重点、难点例题解析 97

综合练习 99

第5章 数组和广义表 101

5.1 数组 101

5.1.1 数组的基本概念 101

5.1.2 数组的存储结构 102

5.2 特殊矩阵的压缩存储 104

5.2.1 对称矩阵 104

5.2.2 三角矩阵 104

5.2.3 对角矩阵 105

5.3 稀疏矩阵 106

5.3.1 定义 106

5.3.2 稀疏矩阵的存储方法 106

5.4 稀疏矩阵的应用案例 110

5.5 广义表 111

5.5.1 广义表的定义及逻辑结构 111

5.5.2 广义表的存储 112

5.5.3 广义表的基本运算 114

小结 114

重点、难点例题解析 115

综合练习 116

第6章 树和二叉树 118

6.1 树的基本概念 118

6.1.1 树的定义 118

6.1.2 树的基本术语 119

6.1.3 树的逻辑表示方法 121

6.2 二叉树 121

6.2.1 二叉树概念及特点 121

6.2.2 二叉树性质 124

6.2.3 二叉树的存储结构 125

6.2.4 二叉树的基本运算及其实现 128

6.3 二叉树的遍历 129

6.3.1 二叉树遍历的概念 129

6.3.2 二叉树遍历的方法 130

6.3.3 二叉树遍历的应用 131

6.3.4 二叉树遍历递归算法 131

6.3.5 二叉树遍历非递归算法 132

6.4 线索二叉树 135

6.4.1 线索二叉树的定义 135

6.4.2 线索二叉树的存储结构 136

6.4.3 线索二叉树的遍历 138

6.5 树和森林 139

6.5.1 树的存储结构 139

6.5.2 树、森林与二叉树的转换 142

6.5.3 树和森林的遍历 143

6.6 哈夫曼树 144

6.6.1 哈夫曼树概述 144

6.6.2 哈夫曼树的构造 145

6.6.3 哈夫曼编码 147

6.7 树的应用案例 149

小结 150

重点、难点例题解析 150

综合练习 154

第7章 图 156

7.1 图的基本概念 156

7.1.1 图的定义 156

7.1.2 图的基本术语 157

7.1.3 图的基本操作 159

7.2 图的存储结构 159

7.2.1 邻接矩阵 160

7.2.2 邻接表 163

7.2.3 十字链表 167

7.2.4 邻接多重表 168

7.2.5 图的存储方法的比较 168

7.3 图的遍历 169

7.3.1 图的遍历的概念 169

7.3.2 深度优先搜索遍历 169

7.3.3 广度优先搜索遍历 170

7.3.4 非连通图的遍历 173

7.4 图的应用 174

7.4.1 最小生成树 174

7.4.2 最短路径 178

7.4.3 拓扑排序 182

7.4.4 AOE网与关键路径 184

7.5 图的应用案例 187

小结 187

重点、难点例题解析 187

综合练习 190

第8章 查找 192

8.1 查找的基本概念 192

8.2 静态查找 193

8.2.1 顺序查找 193

8.2.2 二分查找 195

8.2.3 分块查找 198

8.3 动态查找 200

8.3.1 二叉排序树 200

8.3.2 二叉平衡树 205

8.3.3 B-树 209

8.3.4 B+树 213

8.4 哈希查找 214

8.4.1 哈希表的基本概念 214

8.4.2 哈希函数的构造方法 214

8.4.3 哈希冲突解决方法 217

8.4.4 哈希表上的运算 218

小结 221

重点、难点例题解析 221

综合练习 224

第9章 排序 227

9.1 排序的基本概念 227

9.1.1 基本概念 227

9.1.2 排序方法的分类 228

9.1.3 待排序序列的存储方法 228

9.2 插入排序 228

9.2.1 直接插入排序 228

9.2.2 希尔排序 230

9.3 交换排序 232

9.3.1 冒泡排序 232

9.3.2 快速排序 233

9.4 选择排序 236

9.4.1 直接选择排序 236

9.4.2 堆排序 238

9.5 二路归并排序 243

9.6 基数排序 244

9.7 各种排序方法的综合比较 248

9.8 外部排序简介 248

小结 249

重点、难点例题解析 249

综合练习 252

综合实验指导 254

实验1 顺序表操作 254

实验2 单链表操作 256

实验3 栈和队列操作 259

实验4 二叉树操作 263

实验5 哈夫曼树操作 265

实验6 图操作 268

实验7 查找操作 273

实验8 排序操作 277

实验9 综合课程设计——学生成绩管理系统 283

附录 291

附录A 各章综合练习参考答案 291

附录B 近三年全国计算机专业数据结构联考试题 305

附录C 近三年全国计算机专业数据结构联考试题参考答案 310

附录D 全国计算机专业数据结构2015年联考大纲 314

参考文献 317

返回顶部