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

数据结构PDF电子书下载

工业技术

  • 电子书积分:9 积分如何计算积分?
  • 作 者:包振宇,孙干,陈勇编著
  • 出 版 社:北京:中国铁道出版社
  • 出版年份:2009
  • ISBN:9787113100117
  • 页数:184 页
图书介绍:本书包括数据结构的理论知识和实验指导两部分,每章又新增了“典型例题”一节。
《数据结构》目录

第一部分 理论知识 1

第1章 绪论 1

1.1 数据结构与算法 1

1.1.1 数据结构的基本概念 1

1.1.2 算法的概念和特性 2

1.2 算法的描述和分析 2

1.2.1 算法的描述 2

1.2.2 算法的分析 2

1.3 典型例题 3

习题1 4

第2章 线性表 7

2.1 线性表的逻辑结构 7

2.2 线性表的顺序存储结构 7

2.2.1 顺序分配 7

2.2.2 线性表的操作 8

2.3 线性表的链式存储结构 12

2.3.1 线性链表的实现 13

2.3.2 线性链表的运算 13

2.3.3 循环链表 18

2.4 典型例题 22

习题2 25

第3章 栈和队列 29

3.1 堆栈 29

3.1.1 堆栈的定义和基本操作 29

3.1.2 顺序存储栈 29

3.1.3 链式存储栈 30

3.2 队列 31

3.2.1 顺序存储队列 32

3.2.2 链式存储队列 33

3.3 典型例题 34

习题3 36

第4章 字符串、数组和广义表 39

4.1 字符串基本概念 39

4.2 字符串的存储结构 39

4.2.1 串的顺序存储结构 39

4.2.2 串的链式存储结构 40

4.3 字符串的模式匹配 40

4.3.1 模式匹配的BF算法 40

4.3.2 模式匹配的KMP算法 42

4.4 数组的基本概念 47

4.5 矩阵的压缩存储 47

4.5.1 特殊矩阵的压缩 47

4.5.2 稀疏矩阵 48

4.6 广义表 55

4.6.1 广义表的存储结构 56

4.6.2 综合举例 57

4.7 典型例题 58

习题4 61

第5章 树 63

5.1 树的定义和术语 63

5.1.1 树的定义 63

5.1.2 树的基本术语 63

5.2 二叉树 64

5.2.1 二叉树的定义和性质 64

5.2.2 二叉树的存储结构 65

5.3 遍历二叉树 67

5.3.1 遍历二叉树的方法 67

5.3.2 遍历二叉树的函数 68

5.4 线索二叉树 69

5.5 树和森林 71

5.5.1 树的存储结构 71

5.5.2 树与二叉树的转换(通过二叉链表存储联系) 73

5.6 树的应用 74

5.6.1 二叉排序树 74

5.6.2 哈夫曼树 76

5.7 典型例题 80

习题5 82

第6章 图 87

6.1 图的基本概念 87

6.1.1 图的定义 87

6.1.2 图的相关术语 88

6.2 图的存储结构 90

6.2.1 邻接矩阵 90

6.2.2 邻接表 91

6.3 图的遍历 92

6.3.1 深度优先搜索(DFS) 92

6.3.2 广度优先搜索(BFS) 93

6.4 最小代价生成树 94

6.4.1 最小代价生成树的概念 94

6.4.2 构造最小生成树的PRIM算法 95

6.5 最短路径 96

6.5.1 从某个顶点到其他顶点的最短路径 96

6.5.2 每一对顶点间的最短路径 97

6.6 拓扑排序 98

6.7 典型例题 100

习题6 101

第7章 查找 106

7.1 线性表的查找 106

7.1.1 顺序存储线性表的查找 106

7.1.2 分块查找 109

7.1.3 链式存储线性表查找 109

7.2 树的查找 110

7.2.1 二叉树查找 110

7.2.2 平衡二叉树 112

7.2.3 B树 114

7.3 哈希表及其查找 115

7.3.1 哈希表 115

7.3.2 常见的散列函数 115

7.3.3 解决冲突的方法 116

7.4 典型例题 117

习题7 118

第8章 排序 120

8.1 选择排序 120

8.2 直接插入排序 124

8.2.1 顺序存储线性表的直接插入排序 124

8.2.2 链式存储线性表的直接插入排序 125

8.3 冒泡排序 129

8.3.1 顺序存储线性表的冒泡排序 129

8.3.2 链式存储线性表的冒泡排序 130

8.4 希尔排序 131

8.5 堆排序 132

8.6 快速排序 134

8.7 合并排序 136

8.8 典型例题 137

习题8 139

第二部分 实验部分 142

实验一 时间复杂度的计算 142

实验二 顺序存储线性表的操作(1) 143

实验三 顺序存储线性表的操作(2) 145

实验四 链式存储线性表的操作(1) 147

实验五 链式存储线性表的操作(2) 150

实验六 链式存储线性表的操作(3) 151

实验七 顺序栈的操作 153

实验八 顺序存储队列的进队列和出队列操作 155

实验九 字符串的操作 157

实验十 数组的操作 159

实验十一 广义表的操作 160

实验十二 树的操作 166

实验十三 图的操作 169

实验十四 二分法查找的操作 174

实验十五 插入排序的操作 176

实验十六 选择排序的操作 178

实验十七 快速排序的操作 180

实验十八 冒泡排序和希尔排序的操作 182

参考文献 184

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