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

数据结构:C语言版PDF电子书下载

工业技术

  • 电子书积分:12 积分如何计算积分?
  • 作 者:崔进平,王聪华,郇正良等编著
  • 出 版 社:北京:中国铁道出版社
  • 出版年份:2008
  • ISBN:9787113087814
  • 页数:342 页
图书介绍:本书内容包括:线性表、栈与队列、二叉树、树与森林、图、查找、排序等。
《数据结构:C语言版》目录

第1章 数据结构概述 1

1.1 数据结构研究的问题 1

1.1.1 计算机解决实际问题的一般步骤 1

1.1.2 数据结构学科概念及其所研究的内容 2

1.1.3 数据结构的建模举例 2

1.2 数据结构的有关概念 5

1.2.1 数据的有关概念 5

1.2.2 数据结构的相关术语 6

1.2.3 数据类型的概念 8

1.3 算法与算法性能分析 9

1.3.1 算法概念及特点 10

1.3.2 算法的设计要求 12

1.3.3 算法的性能分析 13

1.4 数据结构与算法描述工具简介 17

习题 19

第2章 线性表 22

2.1 线性表的类型定义 22

2.1.1 线性表的概念与逻辑结构 22

2.1.2 线性表的ADT定义 23

2.2 线性表的顺序存储结构及其算法实现 25

2.2.1 线性表的顺序存储结构 25

2.2.2 顺序表的基本算法实现 27

2.2.3 顺序表应用举例 30

2.3 线性表的链式存储与算法实现 33

2.3.1 单链表存储结构 33

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

2.3.3 双向链表 44

2.3.4 循环链表 46

2.3.5 静态链表 47

2.3.6 单链表应用举例 48

习题 52

第3章 栈和队列 56

3.1 栈 56

3.1.1 栈的概念及ADT定义 56

3.1.2 栈的存储表示与算法实现 57

3.2 栈的应用举例 63

3.3 队列 78

3.3.1 队列的定义及ADT定义 78

3.3.2 队列的存储结构及算法实现 80

习题 86

第4章 串 90

4.1 串的概念及其ADT定义 90

4.1.1 串的基本概念及术语 90

4.1.2 串的ADT定义 90

4.2 串的定长顺序存储及基本运算 92

4.2.1 串的定长顺序存储表示及其算法实现 92

4.2.2 定长顺序串的基本运算 93

4.3 串的堆存储结构及算法实现 95

4.3.1 串的堆存储结构 96

4.3.2 堆串的算法实现 97

4.4 串的匹配算法 99

4.4.1 简单匹配算法 99

4.4.2 KMP匹配算法 101

4.4.3 串的其他存储映像 105

习题 107

第5章 数组与广义表 110

5.1 数组 110

5.1.1 数组类型与存储结构 110

5.1.2 数组的内存映像 111

5.2 特殊矩阵的压缩存储 114

5.2.1 对称矩阵 114

5.2.2 三角矩阵 115

5.2.3 带状矩阵 117

5.3 稀疏矩阵 117

5.3.1 稀疏矩阵的三元组存储结构与矩阵的转置和乘法 118

5.3.2 稀疏矩阵的十字链表存储与矩阵的加法和减法 124

5.4 广义表 128

5.4.1 广义表的概念与ADT定义 128

5.4.2 广义表的存储 131

5.4.3 广义表的基本操作算法 133

5.4.4 广义表的应用举例 136

习题 138

第6章 二叉树 142

6.1 二叉树的概念与性质 142

6.1.1 二叉树的定义及相关术语 142

6.1.2 二叉树的性质 146

6.2 二叉树的存储结构与创建算法 148

6.2.1 二叉树的存储结构 148

6.2.2 二叉树的创建算法 152

6.3 二叉树的遍历算法及其应用 153

6.3.1 二叉树的递归遍历算法 153

6.3.2 二叉树的非递归遍历算法 155

6.3.3 二叉树遍历算法的应用 159

6.3.4 由遍历序列恢复二叉树 162

6.4 线索二叉树 165

6.4.1 线索二叉树的定义及结构 166

6.4.2 线索二叉树的基本操作算法 168

6.5 哈夫曼树 173

6.5.1 哈夫曼树的概念与构造算法 173

6.5.2 哈夫曼的应用 177

习题 182

第7章 树与森林 187

7.1 树的概念与ADT定义 187

7.1.1 树的定义及其相关术语 187

7.1.2 树的ADT定义 190

7.1.3 树与森林的性质 191

7.2 树与森林的存储结构 192

7.3 树、森林与二叉树的转换 197

7.3.1 树转换成二叉树 197

7.3.2 森林转换成二叉树 198

7.3.3 二叉树转换成树或森林 199

7.4 树和森林的遍历 200

7.4.1 树的遍历 200

7.4.2 森林的遍历 201

7.5 树的应用 201

7.5.1 集合的表示 201

7.5.2 求等价类问题 203

习题 204

第8章 图 207

8.1 图的基本概念与类型定义 207

8.1.1 图的概念与相关术语 207

8.1.2 图的ADT定义 211

8.2 图的存储表示与创建算法 212

8.2.1 邻接矩阵存储表示与创建算法 212

8.2.2 邻接表存储表示与创建算法 215

8.2.3 有向图的十字链表存储表示与创建算法 217

8.2.4 无向图的邻接多重表存储表示 219

8.3 图的遍历算法 220

8.3.1 深度优先搜索算法 221

8.3.2 广度优先搜索算法 222

8.4 图的连通性 224

8.4.1 无向图的连通性 224

8.4.2 有向图的连通性 225

8.4.3 生成树和生成森林 225

8.4.4 关结点和重连通分量 227

8.5 最小生成树 230

8.5.1 最小生成树的概念 230

8.5.2 构造最小生成树的Prim算法 231

8.5.3 构造最小生成树的Kruskal算法 234

8.6 最短路径问题 236

8.6.1 从一个源点到其他各顶点的最短路径 236

8.6.2 每一对顶点之间的最短路径 239

8.7 有向无环图及其应用 241

8.7.1 有向无环图的概念 241

8.7.2 AOV网与拓扑排序 242

8.7.3 AOE网与关键路径 247

习题 251

第9章 查找 256

9.1 查找概述 256

9.1.1 查找表的有关概念 256

9.1.2 查找表的类型说明 257

9.1.3 查找算法的性能分析 258

9.2 静态查找表 258

9.2.1 静态查找表的结构 258

9.2.2 顺序表的查找 259

9.2.3 有序表的查找 260

9.2.4 有序表的其他查找方法 265

9.2.5 静态树表的查找 267

9.3 动态查找表 270

9.3.1 二叉排序树 271

9.3.2 平衡二叉树(AVL树) 277

9.3.3 B-树和B+树 286

9.4 哈希表查找 296

9.4.1 哈希表与哈希方法 296

9.4.2 哈希函数的常用构造方法 297

9.4.3 处理冲突的方法 299

9.4.4 哈希表的查找分析 301

习题 304

第10章 排序 308

10.1 基本概念 308

10.2 插入排序 309

10.2.1 直接插入排序 310

10.2.2 折半插入排序 312

10.2.3 表插入排序 313

10.2.4 希尔排序 315

10.3 交换排序 317

10.3.1 冒泡排序 317

10.3.2 快速排序 319

10.4 选择排序 322

10.4.1 简单选择排序 322

10.4.2 树形选择排序 324

10.4.3 堆排序(heap sort) 325

10.5 二路归并排序 328

10.6 基数排序 329

10.6.1 多关键字排序 329

10.6.2 链式基数排序 330

10.6.3 计数排序 333

10.7 各种排序算法的比较 334

10.8 外排序 335

10.8.1 外部排序的方法 335

10.8.2 多路平衡归并的实现 336

习题 339

参考文献 342

相关图书
作者其它书籍
返回顶部