图书介绍

数据结构 C语言 微课版pdf电子书版本下载

数据结构  C语言  微课版
  • 王海艳主编;骆健,朱浩,邹志强,戴华,徐鹤,王苏副主编 著
  • 出版社: 北京:人民邮电出版社
  • ISBN:9787115458254
  • 出版时间:2017
  • 标注页数:203页
  • 文件大小:33MB
  • 文件页数:212页
  • 主题词:数据结构-高等学校-教材;C语言-程序设计-高等学校-教材

PDF下载


点此进入-本书在线PDF格式电子书下载【推荐-云解压-方便快捷】直接下载PDF格式图书。移动端-PC端通用
下载压缩包 [复制下载地址] 温馨提示:(请使用BT下载软件FDM进行下载)软件下载地址页

下载说明

数据结构 C语言 微课版PDF格式电子书版下载

下载的文件为RAR压缩包。需要使用解压软件进行解压得到PDF格式图书。

建议使用BT下载工具Free Download Manager进行下载,简称FDM(免费,没有广告,支持多平台)。本站资源全部打包为BT种子。所以需要使用专业的BT下载软件进行下载。如 BitComet qBittorrent uTorrent等BT下载工具。迅雷目前由于本站不是热门资源。不推荐使用!后期资源热门了。安装了迅雷也可以迅雷进行下载!

(文件页数 要大于 标注页数,上中下等多册电子书除外)

注意:本站所有压缩包均有解压码: 点击下载压缩包解压工具

图书目录

第1章 绪论 1

1.1 数据结构起源 1

1.2 基本概念和术语 1

1.2.1 基本概念 1

1.2.2 数据结构 2

1.3 抽象数据类型 4

1.4 算法和算法分析 5

1.4.1 算法 5

1.4.2 算法的时间复杂度 5

1.4.3 最坏、最好和平均情况时间复杂度 6

1.4.4 算法的空间复杂度 7

1.5 微课(一) 7

习题 7

第2章 线性表 9

2.1 线性表定义 9

2.2 线性表的顺序存储结构和实现 10

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

2.2.2 顺序表基本运算的实现 10

2.3 线性表的链式存储结构和实现 14

2.3.1 单链表的定义和表示 15

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

2.3.3 带表头结点的单链表 20

2.3.4 单循环链表 22

2.3.5 双向链表 22

2.4 顺序表与链表的比较 23

2.5 线性表的应用 24

2.6 微课(二) 27

习题 27

第3章 堆栈和队列 29

3.1 堆栈 29

3.1.1 堆栈ADT 29

3.1.2 堆栈的顺序表示 30

3.1.3 堆栈的链接表示 31

3.2 队列 32

3.2.1 队列ADT 32

3.2.2 队列的顺序表示 32

3.2.3 队列的链接表示 35

3.3 表达式计算 35

3.3.1 中缀表达式 35

3.3.2 后缀表达式及其求值方法 36

3.3.3 中缀表达式转换为后缀表达式 39

3.4 递归 41

3.4.1 递归的概念 41

3.4.2 递归的实现 42

3.5 微课(三) 43

习题 43

第4章 数组和字符串 45

4.1 数组 45

4.1.1 一维数组 45

4.1.2 二维数组 46

4.1.3 多维数组 47

4.2 数组的抽象数据类型 47

4.3 特殊矩阵 50

4.3.1 对称矩阵 50

4.3.2 三角矩阵 51

4.4 稀疏矩阵 52

4.4.1 稀疏矩阵的抽象数据类型 52

4.4.2 稀疏矩阵的简单转置算法 54

4.4.3 稀疏矩阵的快速转置算法 55

4.5 字符串 57

4.5.1 字符串的抽象数据类型 57

4.5.2 简单字符串匹配算法 58

4.5.3 改进的字符串匹配算法 61

4.6 微课(四) 65

习题 65

第5章 树和二叉树 67

5.1 树 67

5.1.1 树的定义 67

5.1.2 基本术语 67

5.1.3 树的抽象数据类型 68

5.1.4 树的存储表示 69

5.2 二叉树 71

5.2.1 二叉树的定义及主要性质 71

5.2.2 二叉树的抽象数据类型 73

5.2.3 二叉树的顺序存储和链式存储表示 74

5.2.4 二叉树的遍历 75

5.2.5 线索二叉树的基本概念和构造 77

5.3 树、森林与二叉树的关系 78

5.3.1 树、森林与二叉树的转换 79

5.3.2 树和森林的遍历 82

5.4 堆和优先权队列 83

5.4.1 堆 83

5.4.2 优先权队列 85

5.5 哈夫曼树及其应用 88

5.5.1 哈夫曼树的基本概念 88

5.5.2 哈夫曼算法 89

5.5.3 哈夫曼编码 90

5.6 微课(五) 92

习题 92

第6章 集合和搜索 95

6.1 集合的表示 95

6.1.1 基本概念 95

6.1.2 动态集ADT 96

6.1.3 集合的表示 96

6.2 顺序搜索 97

6.2.1 无序表的顺序搜索 97

6.2.2 有序表的顺序搜索 98

6.3 对半搜索 98

6.3.1 对半搜索方法 98

6.3.2 二叉判定树 101

6.4 微课(六) 102

习题 102

第7章 搜索树 104

7.1 二叉搜索树 104

7.1.1 二叉搜索树的定义和表示 104

7.1.2 二叉搜索树基本运算的实现 105

7.2 二叉平衡树 109

7.2.1 二叉平衡树的定义和表示 109

7.2.2 AVL搜索树基本运算的实现 111

7.3 B-树 113

7.3.1 B-树的定义和表示 114

7.3.2 B-树基本运算的实现 116

7.4 微课(七) 120

习题 120

第8章 跳表和散列表 122

8.1 跳表 122

8.1.1 跳表的定义和表示 122

8.1.2 跳表基本操作的实现 123

8.2 散列表 125

8.2.1 散列表的定义和表示 125

8.2.2 散列表基本操作的实现 127

8.3 微课(八) 132

习题 132

第9章 图 134

9.1 图的基本概念 134

9.1.1 图的定义 134

9.1.2 图的基本术语 135

9.1.3 图的类型定义 137

9.2 图的存储结构 137

9.2.1 邻接矩阵表示法 137

9.2.2 邻接矩阵的实现 138

9.2.3 图的邻接表表示法 141

9.2.4 邻接表的实现 141

9.3 图的遍历 144

9.3.1 深度优先遍历 144

9.3.2 宽度优先遍历 146

9.4 拓扑排序 148

9.4.1 AOV网 148

9.4.2 拓扑排序 149

9.5 关键路径 150

9.5.1 AOE网 150

9.5.2 关键路径 151

9.6 最小代价生成树 154

9.6.1 基本概念 154

9.6.2 普里姆(Prim)算法 154

9.6.3 克鲁斯卡尔(Kruskal)算法 156

9.7 单源最短路径 159

9.7.1 最短路径 159

9.7.2 单源最短路径 159

9.8 所有顶点之间的最短路径 163

9.9 微课(九) 165

习题 165

第10章 排序 168

10.1 排序的基本概念 168

10.2 简单排序算法 169

10.2.1 简单选择排序 169

10.2.2 直接插入排序 172

10.2.3 冒泡排序 174

10.3 快速排序算法 177

10.4 两路合并排序 181

10.5 堆排序 184

10.6 外排序 187

10.6.1 预处理 187

10.6.2 多路合并 191

10.6.3 最佳合并树 195

10.6.4 完整的外排序过程 196

10.7 微课(十) 196

习题 196

附录 综合实验 199

精品推荐