《数据结构与算法设计》PDF下载

  • 购买积分:12 如何计算积分?
  • 作  者:周海鹰编著
  • 出 版 社:北京:国防工业出版社
  • 出版年份:2009
  • ISBN:9787118063363
  • 页数:322 页
图书介绍:本书主要介绍了数据结构的基本概念和基本算法。全书共分11章。前6章主要介绍了绪论、线性表、栈和队列、串、递归、数组特殊矩阵和广义表,后5章主要介绍了树、图、查找、排序和文件。本书内容详细,基本原理与算法实现相互结合并配套了大量典型例题,便于初学者掌握重要的概念、原理和算法设计方法,也方便了读者复习该门课程的重要知识点。

第1章 绪论 1

1.1 什么是数据结构 1

1.2 基本概念和术语 3

1.3 数据结构的发展及其重要地位 9

1.4 算法的描述和算法分析 10

1.4.1 算法的描述 10

1.4.2 算法设计的要求 12

1.4.3 算法效率的度量 13

1.4.4 算法的存储空间需求 15

1.5 典型例题 15

习题1 18

第2章 线性表 19

2.1 线性表的逻辑结构 19

2.1.1 线性表的定义 19

2.1.2 线性表的基本操作 19

2.2 线性表的顺序存储及运算实现 20

2.2.1 顺序表 20

2.2.2 顺序表上基本运算的实现 21

2.2.3 顺序表应用举例 24

2.3 线性表的链式存储和运算实现 26

2.3.1 单链表 27

2.3.2 单链表上基本运算的实现 28

2.3.3 循环链表 34

2.3.4 双向链表 35

2.3.5 静态链表 36

2.3.6 单链表应用举例 37

2.4 顺序表和链表的比较 39

2.5 典型例题 40

习题2 53

第3章 栈和队列 54

3.1 栈 54

3.1.1 栈的定义及基本运算 54

3.1.2 栈的存储实现和运算实现 54

3.2 栈的应用举例 57

3.3 队列 66

3.3.1 队列的定义及基本运算 66

3.3.2 队列的存储实现及运算实现 66

3.4 队列应用举例 72

3.5 典型例题 74

习题3 81

第4章 串 82

4.1 串的概念和基本运算 82

4.1.1 串的基本概念 82

4.1.2 串的基本运算 82

4.2 串的存储结构 83

4.2.1 串的静态存储结构 83

4.2.2 串的动态存储结构 86

4.3 字符串的模式匹配 91

4.3.1 Brute-Force算法 91

4.3.2 KMP算法 93

4.4 串应用——文本编辑软件 96

4.5 典型例题 102

习题4 108

第5章 递归 109

5.1 递归的概念 109

5.2 用C语言实现递归 111

5.3 递归算法的设计 113

5.4 递归模拟 115

5.4.1 递归的实现机制 115

5.4.2 用非递归算法模拟递归算法 116

习题5 122

第6章 数组、特殊矩阵和广义表 123

6.1 数组的定义及运算 123

6.1.1 数组的定义 123

6.1.2 数组的基本操作 124

6.2 数组的存储结构 124

6.3 矩阵的压缩存储 125

6.3.1 特殊矩阵的压缩存储 125

6.3.2 稀疏矩阵的压缩存储 127

6.4 广义表 132

6.4.1 广义表的定义和基本运算 132

6.4.2 广义表的存储 134

6.5 典型例题 136

习题6 138

第7章 树形结构 139

7.1 树的概念 139

7.1.1 树的定义 139

7.1.2 树的表示方法 140

7.1.3 树的基本术语 141

7.1.4 树的存储结构 141

7.1.5 树的遍历 144

7.2 二叉树 145

7.2.1 二叉树的基本概念 145

7.2.2 叉树的性质 145

7.3 二叉树的存储结构 147

7.3.1 顺序存储结构 147

7.3.2 链式存储结构 149

7.4 二叉树的遍历 149

7.4.1 二叉树遍历的定义 149

7.4.2 二叉树遍历的递归实现 150

7.4.3 二叉树遍历的非递归实现 152

7.5 二叉树其他运算的实现 155

7.6 线索二叉树 157

7.6.1 线索二叉树的定义 157

7.6.2 中序线索二叉树的存储结构及其实现 158

7.7 树、森林和二叉树的转换 160

7.7.1 树、森林到二叉树的转换 160

7.7.2 叉树到树、森林的转换 161

7.8 树的应用 161

7.8.1 哈夫曼树及其应用 161

7.8.2 判定树 165

7.9 典型例题 167

习题7 175

第8章 图 177

8.1 图的基本概念 177

8.2 图的存储结构 180

8.2.1 邻接矩阵 180

8.2.2 邻接表 183

8.2.3 十字链表 189

8.2.4 邻接多重表 190

8.3 图的遍历 191

8.3.1 深度优先搜索的遍历方法 191

8.3.2 广度优先搜索的遍历方法 193

8.4 最小生成树 194

8.4.1 最小生成树的基本概念 194

8.4.2 prim算法构造最小生成树 195

8.4.3 Kruskal算法构造最小生成树 197

8.5 最短路径问题 199

8.5.1 单源最短路径 200

8.5.2 每对顶点之间的最短路径 203

8.6 拓扑排序 205

8.7 关键路径问题 207

8.8 典型例题 211

习题8 224

第9章 查找 226

9.1 静态查找表 226

9.1.1 顺序查找 226

9.1.2 二分法查找 227

9.1.3 分块查找 231

9.2 树表的动态查找 232

9.2.1 二叉排序树 232

9.2.2 平衡二叉树 238

9.2.3 B-树 244

9.2.4 B+树 250

9.3 哈希表与哈希表的查找 250

9.3.1 哈希表的概念 250

9.3.2 构造哈希函数的方法 251

9.3.3 哈希冲突的解决方法 254

9.3.4 哈希表的查找 256

9.3.5 哈希表查找效率分析 257

9.4 典型例题 258

习题9 271

第10章 排序 272

10.1 排序的基本概念 272

10.2 排序方法分类 272

10.3 插入排序 273

10.3.1 直接插入排序 273

10.3.2 Shell排序 275

10.4 选择排序 276

10.4.1 直接选择排序 277

10.4.2 堆排序 278

10.5 交换排序 282

10.5.1 冒泡排序 282

10.5.2 快速排序 283

10.6 归并排序 286

10.7 基数排序 289

10.7.1 多关键字排序 289

10.7.2 链式基数排序 290

10.8 各种内排序算法的比较 293

10.9 外排序 293

10.9.1 外部排序的方法 293

10.9.2 多路平衡归并的实现 295

10.10 典型例题 298

习题10 309

第11章 文件 310

11.1 文件的基本概念 310

11.2 顺序文件 312

11.3 索引文件 313

11.4 索引顺序文件 314

11.4.1 ISAM文件 315

11.4.2 VSAM文件 317

11.5 散列文件 318

11.5.1 多重表文件 319

11.5.2 倒排文件 320

习题11 321

参考文献 322