当前位置:首页 > 工业技术
数据结构与算法  C语言版
数据结构与算法  C语言版

数据结构与算法 C语言版PDF电子书下载

工业技术

  • 电子书积分:10 积分如何计算积分?
  • 作 者:徐凤生主编
  • 出 版 社:北京:机械工业出版社
  • 出版年份:2010
  • ISBN:9787111321224
  • 页数:239 页
图书介绍:本书是作者针对数据结构课程概念多、算法灵活和抽象性强的特点,在总结长期教学经验的基础上编写而成的。本书共10章,内容涵盖数据结构的基本概念,定义了线性表、栈、队列、串、数组、广义表、树和二叉树、图、查找、排序等各种结构的抽象数据类型,并给出了相应操作的实现算法。采用C语言描述算法,并给出了各种算法的效率分析,以及这些结构在计算机科学及其他领域的应用。每章后均配有典型算法设计、上机实验题和练习题。所有算法都在VC++环境下调试通过。
《数据结构与算法 C语言版》目录

第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

习题 13

第2章 线性表 16

2.1 线性表的定义 16

2.1.1 线性表的概念 16

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

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

2.2.1 线性表的顺序表示 17

2.2.2 线性表的顺序实现 18

2.2.3 顺序表的应用举例 21

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

2.3.1 单链表 22

2.3.2 双向链表 26

2.3.3 循环链表 29

2.3.4 静态链表 31

2.3.5 链表的应用举例 33

2.4 典型例题 35

2.5 上机实验 37

习题 39

第3章 栈与队列 41

3.1 栈 41

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

3.1.2 栈的表示与实现 42

3.2 栈的应用举例 44

3.2.1 数制转换 44

3.2.2 括号匹配的检验 45

3.2.3 表达式求值 46

3.2.4 求命题公式的真值 50

3.3 栈与递归实现 53

3.3.1 递归的定义 53

3.3.2 递归与栈的关系 53

3.3.3 递归的实现 54

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

3.3.5 递归的消除 57

3.4 队列 59

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

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

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

3.4.4 队列的应用举例 63

3.5 典型例题 64

3.6 上机实验 66

习题 68

第4章 串 70

4.1 串的定义 70

4.2 串的表示与实现 72

4.2.1 串的顺序存储表示 72

4.2.2 串的链式存储表示 75

4.3 串的模式匹配 75

4.3.1 简单匹配算法 75

4.3.2 首尾匹配算法 77

4.3.3 KMP算法 78

4.4 典型例题 80

4.5 上机实验 82

习题 83

第5章 数组与广义表 85

5.1 数组的定义 85

5.2 数组的顺序存储 86

5.3 矩阵的压缩存储 88

5.3.1 特殊矩阵 89

5.3.2 稀疏矩阵 90

5.4 广义表 94

5.4.1 广义表的定义 94

5.4.2 广义表的存储结构 96

5.5 典型例题 98

5.6 上机实验 99

习题 100

第6章 树与二叉树 101

6.1 树的定义 101

6.1.1 树的概念与术语 101

6.1.2 树的逻辑表示方法 102

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

6.2 二叉树的定义 103

6.2.1 二叉树的概念 103

6.2.2 二叉树的重要性质 105

6.3 二叉树的存储结构 106

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

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

6.4 二叉树的遍历 108

6.4.1 二叉树遍历的概念 108

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

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

6.4.4 层次遍历算法 111

6.4.5 遍历算法的应用举例 112

6.5 二叉树的构造 115

6.6 线索二叉树 116

6.6.1 线索二叉树的定义 116

6.6.2 线索链表的建立 117

6.6.3 线索链表的遍历算法 118

6.7 树和森林的表示方法 119

6.7.1 双亲表示法 119

6.7.2 孩子链表表示法 120

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

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

6.8 树和森林的遍历 122

6.8.1 树的遍历 122

6.8.2 森林的遍历 123

6.8.3 树遍历算法的应用 124

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

6.9.1 赫夫曼树的定义 125

6.9.2 赫夫曼树的构造 125

6.9.3 赫夫曼编码 127

6.10 典型例题 128

6.11 上机实验 130

习题 130

第7章 图 133

7.1 图的定义与术语 133

7.1.1 图的相关术语 133

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

7.2 图的存储表示 136

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

7.2.2 图的邻接表存储表示 137

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

7.2.4 无向图的邻接多重表存储表示 140

7.3 图的遍历 141

7.3.1 深度优先搜索遍历图 141

7.3.2 广度优先搜索遍历图 142

7.3.3 图遍历的应用举例 143

7.4 最小生成树 145

7.4.1 普里姆算法 145

7.4.2 克鲁斯卡尔算法 147

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

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

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

7.6 拓扑排序 151

7.7 关键路径 153

7.8 典型例题 156

7.9 上机实验 158

习题 160

第8章 查找 162

8.1 基本概念 162

8.2 静态查找表 163

8.2.1 顺序查找 163

8.2.2 有序表查找 164

8.2.3 索引查找 167

8.3 动态查找树表 168

8.3.1 二叉排序树 169

8.3.2 平衡二叉树 173

8.3.3 B-树 179

8.3.4 B+树 183

8.3.5 键树 184

8.4 哈希表 185

8.4.1 哈希表的概念 185

8.4.2 哈希函数的构造方法 185

8.4.3 处理冲突的方法 187

8.4.4 哈希表的查找 189

8.4.5 哈希表的插入操作 190

8.4.6 哈希表的删除操作 191

8.5 典型例题 191

8.6 上机实验 193

习题 194

第9章 排序 196

9.1 概述 196

9.1.1 什么是排序 196

9.1.2 内部排序和外部排序 196

9.1.3 内部排序的方法 197

9.2 插入排序 198

9.2.1 直接插入排序 198

9.2.2 折半插入排序 199

9.2.3 二路插入排序 200

9.2.4 表插入排序 202

9.2.5 希尔排序 204

9.3 交换排序 205

9.3.1 起泡排序 205

9.3.2 快速排序 206

9.4 选择排序 209

9.4.1 简单选择排序 209

9.4.2 堆排序 209

9.5 归并排序 212

9.6 基数排序 213

9.6.1 多关键字排序 213

9.6.2 链式基数排序 214

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

9.8 外排序简介 217

9.8.1 外存信息的存取 218

9.8.2 外排序的基本方法 218

9.9 典型例题 219

9.10 上机实验 221

习题 222

第10章 文件 224

10.1 文件的基本概念 224

10.1.1 什么是文件 224

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

10.1.3 文件的存储结构 225

10.2 顺序文件 225

10.3 索引文件 226

10.3.1 ISAM文件 227

10.3.2 VSAM文件 229

10.4 哈希文件 231

10.5 多关键字文件 232

10.5.1 多重表文件 232

10.5.2 倒排文件 232

10.5.3 倒排文件的应用 234

10.6 典型例题 235

10.7 上机实验 237

习题 237

参考文献 239

返回顶部