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

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

工业技术

  • 电子书积分:9 积分如何计算积分?
  • 作 者:邓奕,王维虎,沈海龙主编;苏艳,薛晓亚,马金霞,张采芳,胡广义,齐晶薇副主编
  • 出 版 社:武汉:华中科技大学出版社
  • 出版年份:2015
  • ISBN:9787568001410
  • 页数:195 页
图书介绍:本书系统介绍了数据结构的概念、原理与技术,主要内容包括绪论,基本数据结构,排序、查找与内存管理,相关工具和文件等。其中,第一章绪论主要对算法描述语言(ADL)、算法书写规范、数据结构与算法基本概念、算法分析基础和算法正确性证明等进行了介绍;第二至五章是基本数据结构部分,主要涉及线性表、堆栈和队列,数组和字符串,树与二叉树,图结构等内容;第七至九章从算法的视角讨论了排序、查找和内存管理等方面的内容,给出了若干典型算法的描述、时间复杂性分析和相关算法的比较等;第六章和十一章分别对递归和随机数两种主要工具进行了讲解,其中随机数是数据结构的新内容;文件这种复杂的数据结构则在第十章中阐明。 本书可作为高等学校计算机相关专业的教材和教学参考书,也可供相关专业的工程技术人员参考使用。
《数据结构 C语言版》目录

第1章 绪论 1

1.1 数据结构简介 1

1.2 基本概念和术语 2

1.3 抽象数据类型 4

1.4 C语言基础 5

1.5 算法和算法分析 6

1.5.1 算法 6

1.5.2 算法设计的要求 7

1.5.3 算法效率的度量 7

1.5.4 算法的存储空间需求 8

本章习题 9

习题答案 9

第2章 线性表 11

2.1 线性表的类型定义 11

2.2 线性表的顺序表示 12

2.3 线性表的链式表示 15

2.3.1 线性链表 15

2.3.2 循环链表 19

2.3.3 双向链表 20

2.4 顺序表和链表的比较 22

2.5 一元多项式的表示及相加 22

本章习题 26

习题答案 28

第3章 栈和队列 33

3.1 栈 33

3.1.1 栈的定义 33

3.1.2 栈的表示 33

3.2 栈的应用举例 37

3.2.1 数制转换 37

3.2.2 程序员终端编辑 37

3.2.3 迷宫求解 38

3.2.4 表达式求解 41

3.3 栈与递归 43

3.4 队列 43

3.4.1 队列的定义 43

3.4.2 链队列——队列的链式表示 44

3.4.3 循环队列——队列的顺序表示 46

本章习题 47

习题答案 48

第4章 串、数组和广义表 51

4.1 串的基本概念及运算 51

4.2 串的存储结构 52

4.2.1 定长顺序存储表示 52

4.2.2 堆分配存储表示 53

4.2.3 串的块链存储表示 54

4.3 串的模式匹配算法 55

4.3.1 求子串位置的定位函数Index(S,T,pos) 55

4.3.2 模式匹配的一种改进算法 56

4.4 串操作应用举例 58

4.4.1 文本编辑 58

4.4.2 建立词索引表 60

4.5 数组的定义 64

4.6 数组的表示 65

4.7 矩阵的压缩存储 66

4.7.1 特殊矩阵 66

4.7.2 稀疏矩阵 68

4.8 广义表的概念 74

4.9 广义表的存储 75

本章习题 76

习题答案 78

第5章 树 86

5.1 树的概念 86

5.1.1 树的定义 86

5.1.2 树的表示方法 87

5.2 二叉树 87

5.2.1 二叉树的定义 87

5.2.2 二叉树的性质 88

5.2.3 二叉树的存储结构 90

5.3 遍历二叉树和线索二叉树 92

5.3.1 遍历二叉树 92

5.3.2 线索二叉树 95

5.4 树与二叉树的转换 98

5.4.1 树的存储结构 98

5.4.2 树与二叉树的转换 100

5.5 赫夫曼树及其应用 102

5.5.1 最优二叉树(赫夫曼树) 102

5.5.2 赫夫曼编码 104

本章习题 106

习题答案 107

第6章 图 113

6.1 图的概念和操作 113

6.2 图的存储结构 116

6.2.1 邻接表 116

6.2.2 十字链表 121

6.2.3 邻接多重表 122

6.3 图的遍历 123

6.3.1 深度优先搜索遍历 123

6.3.2 广度优先搜索遍历 124

6.4 图的连通性问题 125

6.4.1 无向图的连通分量和生成树 126

6.4.2 有向图的强连通分量 127

6.4.3 最小生成树 129

6.5 有向无环图及其应用 132

6.5.1 拓扑排序 132

6.5.2 关键路径 134

6.6 最短路径 136

6.6.1 单源最短路径 136

6.6.2 所有顶点对之间的最短路径 137

本章习题 139

习题答案 140

第7章 查找 145

7.1 静态查找表 145

7.1.1 顺序表的查找 145

7.1.2 有序表的查找 146

7.1.3 静态树表的查找 148

7.1.4 索引顺序表的查找 150

7.2 动态查找表 150

7.2.1 二叉排序树和平衡二叉树 151

7.2.2 B_树和B+树 158

7.3 哈希表(散列表) 163

7.3.1 哈希表的概念 163

7.3.2 哈希函数的构造方法 164

7.3.3 处理冲突的方法 165

7.3.4 哈希表的查找及其分析 167

本章习题 168

习题答案 168

第8章 排序 171

8.1 排序概述 171

8.2 插入排序 172

8.2.1 直接插入排序 172

8.2.2 其他插入排序 173

8.2.3 希尔排序 175

8.3 交换排序 176

8.3.1 冒泡排序 176

8.3.2 快速排序 177

8.4 选择排序 178

8.4.1 简单选择排序 179

8.4.2 树形选择排序 179

8.4.3 堆排序 180

8.5 归并排序 183

8.5.1 两路归并的迭代算法 183

8.5.2 两路归并的递归算法 184

8.6 基数排序 185

8.6.1 多关键字的排序 185

8.6.2 链式基数排序 186

8.7 各种内部排序方法的比较讨论 188

8.8 外部排序简介 189

本章习题 191

习题答案 191

参考文献 195

返回顶部