《数据结构与算法 C语言版》PDF下载

  • 购买积分:11 如何计算积分?
  • 作  者:徐凤生编著
  • 出 版 社:北京:机械工业出版社
  • 出版年份:2014
  • ISBN:9787111479406
  • 页数:278 页
图书介绍:本书共11章,一方面,涵盖数据结构的基本概念,定义了线性表、栈、队列、串、数组、广义表、树和二叉树、图、查找、排序等各种结构的抽象数据类型,给出了相应操作的实现算法,并在最后一章给出了几个课程设计的实例。另一方面,采用C语言描述算法,并给出了各种算法的效率分析,以及这些结构在计算机科学及其他领域的应用。此外,每章后均配有典型例题、上机实验和习题。本书中的所有算法都在VC++环境下调试通过。本书在内容安排上,突出由浅入深、循序渐进、通俗易懂的特点。算法分析透彻,讲解清晰,便于学生自学。为了激发学生的学习兴趣,培养学生解决实际问题的能力,书中融入了一些典型的应用实例,如命题公式真值表的求解算法、出栈序列的求解算法等。本书可作为高等院校计算机及相关专业本科生的“数据结构”课程教材,也可供相关科技人员学习参考。

第1章 绪论 1

1.1 数据结构的研究对象 1

1.2 数据结构的发展概况 4

1.3 基本概念与术语 4

1.4 数据类型与抽象数据类型 6

1.4.1 数据类型 6

1.4.2 抽象数据类型 6

1.4.3 抽象数据类型的表示与实现 7

1.5 算法与算法分析 9

1.5.1 算法 9

1.5.2 算法设计的原则 10

1.5.3 算法效率的衡量方法和准则 10

1.5.4 算法的存储空间需求 12

1.6 典型例题 12

1.7 上机实验 13

1.8 小结 13

习题 15

第2章 线性表 17

2.1 线性表的定义 17

2.1.1 线性表的概念 17

2.1.2 线性表的抽象数据类型定义 17

2.2 线性表的顺序表示与实现 18

2.2.1 线性表的顺序表示 18

2.2.2 线性表的顺序实现 19

2.2.3 顺序表的应用举例 22

2.3 线性表的链式表示与实现 23

2.3.1 单链表 23

2.3.2 双向链表 27

2.3.3 循环链表 30

2.3.4 静态链表 32

2.3.5 链表的应用举例 34

2.4 典型例题 36

2.5 上机实验 38

2.6 小结 40

习题 41

第3章 栈与队列 43

3.1 栈 43

3.1.1 栈的抽象数据类型定义 43

3.1.2 栈的表示与实现 44

3.2 栈的应用举例 46

3.2.1 数制转换 46

3.2.2 括号匹配的检验 47

3.2.3 表达式求值 48

3.2.4 求命题公式的真值 52

3.3 栈与递归实现 55

3.3.1 递归的定义 55

3.3.2 递归与栈的关系 55

3.3.3 递归的实现 56

3.3.4 用递归求所有出栈序列 58

3.3.5 递归的消除 59

3.4 队列 61

3.4.1 队列的抽象数据类型定义 61

3.4.2 队列的链式表示与实现 62

3.4.3 队列的顺序表示与实现——循环队列 63

3.4.4 队列的应用举例 65

3.5 典型例题 66

3.6 上机实验 68

3.7 小结 70

习题 71

第4章 串 73

4.1 串的定义 73

4.2 串的表示与实现 75

4.2.1 串的顺序存储表示 75

4.2.2 串的链式存储表示 78

4.3 串的模式匹配 78

4.3.1 简单匹配算法 79

4.3.2 首尾匹配算法 80

4.3.3 KMP算法 81

4.4 典型例题 83

4.5 上机实验 85

4.6 小结 86

习题 86

第5章 数组与广义表 88

5.1 数组的定义 88

5.2 数组的顺序存储 89

5.3 矩阵的压缩存储 91

5.3.1 特殊矩阵 92

5.3.2 稀疏矩阵 93

5.4 广义表 97

5.4.1 广义表的定义 97

5.4.2 广义表的存储结构 99

5.5 典型例题 101

5.6 上机实验 102

5.7 小结 103

习题 103

第6章 树与二叉树 105

6.1 树的定义 105

6.1.1 树的概念与术语 105

6.1.2 树的逻辑表示方法 106

6.1.3 树的抽象数据类型定义 106

6.2 二叉树的定义 107

6.2.1 二叉树的概念 107

6.2.2 二叉树的重要性质 109

6.3 二叉树的存储结构 110

6.3.1 二叉树的顺序存储表示 110

6.3.2 二叉树的链式存储表示 110

6.4 二叉树的遍历 112

6.4.1 二叉树遍历的概念 112

6.4.2 二叉树遍历的递归算法 112

6.4.3 二叉树遍历的非递归算法 113

6.4.4 层次遍历算法 115

6.4.5 遍历算法的应用举例 116

6.5 二叉树的构造 119

6.6 线索二叉树 120

6.6.1 线索二叉树的定义 120

6.6.2 线索链表的建立 121

6.6.3 线索链表的遍历算法 122

6.7 树和森林的表示方法 123

6.7.1 双亲表示法 123

6.7.2 孩子链表表示法 124

6.7.3 孩子-兄弟链表表示法 125

6.7.4 树、森林和二叉树的对应关系 125

6.8 树和森林的遍历 126

6.8.1 树的遍历 126

6.8.2 森林的遍历 127

6.8.3 树遍历算法的应用 128

6.9 赫夫曼树与赫夫曼编码 128

6.9.1 赫夫曼树的定义 129

6.9.2 赫夫曼树的构造 129

6.9.3 赫夫曼编码 131

6.10 典型例题 132

6.11 上机实验 134

6.12 小结 134

习题 135

第7章 图 138

7.1 图的定义与术语 138

7.1.1 图的相关术语 138

7.1.2 图的抽象数据类型定义 140

7.2 图的存储表示 141

7.2.1 图的邻接矩阵存储表示 141

7.2.2 图的邻接表存储表示 142

7.2.3 有向图的十字链表存储表示 143

7.2 4 无向图的邻接多重表存储表示 145

7.3 图的遍历 146

7.3.1 深度优先搜索遍历图 146

7.3.2 广度优先搜索遍历图 147

7.3.3 图遍历的应用举例 148

7.4 最小生成树 150

7.4.1 普里姆算法 150

7.4.2 克鲁斯卡尔算法 152

7.5 两点之间的最短路径问题 153

7.5.1 从某个源点到其余各点的最短路径 153

7.5.2 每一对顶点之间的最短路径 155

7.6 拓扑排序 156

7.7 关键路径 158

7.8 典型例题 161

7.9 上机实验 163

7.10 小结 165

习题 166

第8章 查找 168

8.1 基本概念 168

8.2 静态查找表 169

8.2.1 顺序查找 169

8.2.2 有序表查找 170

8.2.3 索引查找 173

8.3 动态查找树表 174

8.3.1 二叉排序树 175

8.3.2 平衡二叉树 179

8.3.3 B-树 185

8.3.4 B+树 189

8.3.5 键树 190

8.4 哈希表 191

8.4.1 哈希表的概念 191

8.4.2 哈希函数的构造方法 191

8.4.3 处理冲突的方法 193

8.4.4 哈希表的查找 195

8.4.5 哈希表的插入操作 196

8.4.6 哈希表的删除操作 197

8.5 典型例题 197

8.6 上机实验 199

8.7 小结 200

习题 201

第9章 排序 203

9.1 概述 203

9.1.1 什么是排序 203

9.1.2 内部排序和外部排序 203

9.1.3 内部排序的方法 204

9.2 插入排序 205

9.2.1 直接插入排序 205

9.2.2 折半插入排序 206

9.2.3 二路插入排序 207

9.2.4 表插入排序 209

9.2.5 希尔排序 211

9.3 交换排序 212

9.3.1 起泡排序 212

9.3.2 快速排序 213

9.4 选择排序 216

9.4.1 简单选择排序 216

9.4.2 堆排序 216

9.5 归并排序 219

9.6 基数排序 220

9.6.1 多关键字排序 220

9.6.2 链式基数排序 221

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

9.8 外排序简介 225

9.8.1 外存信息的存取 225

9.8.2 外排序的基本方法 225

9.9 典型例题 226

9.10 上机实验 228

9.11 小结 229

习题 231

第10章 文件 233

10.1 文件的基本概念 233

10.1.1 什么是文件 233

10.1.2 文件的逻辑结构及操作 233

10.1.3 文件的存储结构 234

10.2 顺序文件 234

10.3 索引文件 235

10.3.1 ISAM文件 236

10.3.2 VSAM文件 238

10.4 哈希文件 240

10.5 多关键字文件 241

10.5.1 多重表文件 241

10.5.2 倒排文件 241

10.5.3 倒排文件的应用 243

10.6 典型例题 244

10.7 上机实验 246

10.8 小结 246

习题 247

第11章 课程设计举例 248

11.1 通讯录管理 248

11.2 停车场管理 253

11.3 文本文件的检索 258

11.4 导师制问题 262

11.5 家谱管理 267

11.6 教学计划安排 272

参考文献 278