数据结构 / 高等学校新工科计算机类专业系列教材
¥39.00定价
作者: 张惠涛
出版时间:2025-02
出版社:西安电子科技大学出版社
- 西安电子科技大学出版社
- 9787560675473
- 1-1
- 549930
- 16开
- 2025-02
- 自动化技术、计算机技术
- 本科
目录
第1章 绪论 1
1.1 数据结构的定义 1
1.1.1 逻辑结构 2
1.1.2 存储结构 6
1.1.3 数据运算 9
1.2 算法和算法分析 9
1.2.1 算法 9
1.2.2 算法分析 10
本章小结 14
习题 14
第2章 线性表 18
2.1 线性表的定义和操作 18
2.1.1 线性表的定义 18
2.1.2 线性表的基本操作 18
2.2 线性表的顺序表示 19
2.2.1 顺序表的定义 19
2.2.2 顺序表上基本操作的实现 20
2.3.3 顺序表的应用举例 25
2.3 线性表的链式表示 27
2.3.1 单链表的定义 27
2.3.2 单链表上基本操作的实现 28
2.3.3 单链表的应用举例 37
2.3.4 双链表 46
2.4 有序表 47
本章小结 50
习题 50
第3章 栈和队列 55
3.1 栈 55
3.1.1 栈的相关概念及基本运算 55
3.1.2 栈的顺序存储结构 56
3.1.3 栈的链式存储结构 59
3.1.4 栈的应用举例 66
3.2 队列 68
3.2.1 队列的相关概念及基本运算 68
3.2.2 队列的顺序存储结构 69
3.2.3 队列的链式存储结构 72
3.2.4 环形队列 77
3.2.5 队列的应用举例 80
本章小结 82
习题 82
第4章 串 85
4.1 串的基本概念及抽象数据类型基本运算 85
4.1.1 串的基本概念 85
4.1.2 串的抽象数据类型基本运算 85
4.2 串的存储结构及基本运算 86
4.2.1 串的顺序存储结构及基本运算 86
4.2.2 串的链式存储结构及基本运算 90
4.3 串的模式匹配 96
4.3.1 Brute Force算法 97
4.3.2 KMP算法 99
4.3.3 模式匹配的实际应用举例 102
本章小结 104
习题 104
第5章 数组和广义表 106
5.1 数组 106
5.1.1 数组的基本概念 106
5.1.2 数组的存储结构 106
5.2 矩阵的压缩存储 108
5.2.1 特殊矩阵 108
5.2.2 稀疏矩阵 110
5.3 广义表 113
5.3.1 广义表的定义 113
5.3.2 广义表的存储 115
5.3.3 广义表的运算 115
本章小结 118
习题 118
第6章 树和二叉树 119
6.1 树的基本概念 119
6.1.1 树的定义 119
6.1.2 树的基本术语 120
6.1.3 树的存储结构 121
6.1.4 树的遍历 123
6.2 二叉树 123
6.2.1 二叉树的定义 123
6.2.2 二叉树的性质 124
6.2.3 二叉树的存储结构 125
6.2.4 二叉树的基本运算及实现 127
6.3 遍历二叉树 129
6.4 二叉树与树、森林之间的转换 133
6.4.1 树、森林转换成二叉树 133
6.4.2 二叉树还原成树、森林 134
6.5 哈夫曼树及其应用 135
6.5.1 哈夫曼树的定义 135
6.5.2 哈夫曼树的构造 136
6.5.3 哈夫曼编码 138
本章小结 140
习题 140
第7章 图 142
7.1 图的定义和术语 142
7.1.1 图的定义 142
7.1.2 图的基本术语 142
7.2 图的存储结构 146
7.2.1 邻接矩阵 146
7.2.2 邻接表 147
7.3 图的遍历 148
7.3.1 深度优先搜索遍历 148
7.3.2 广度优先搜索遍历 150
7.4 最小生成树 151
7.4.1 生成树的相关概念 151
7.4.2 普里姆(Prim)算法 152
7.4.3 克鲁斯卡尔( Kruskal)算法 154
7.5 有向无环图的应用 158
7.5.1 拓扑排序 158
7.5.2 关键路径 159
7.6 最短路径 161
7.6.1 单源最短路径问题:Dijkstra算法 162
7.6.2 多源最短路径问题:Floyd算法 166
本章小结 171
习题 171
第8章 查找 173
8.1 查找的相关概念 173
8.2 线性表的查找 174
8.2.1 顺序查找 175
8.2.2 折半查找 175
8.2.3 分块查找 177
8.3 树表的查找 179
8.4 哈希表的查找 185
8.4.1 哈希表的相关概念 185
8.4.2 构造哈希函数的方法 186
8.4.3 处理冲突的方法 187
本章小结 190
习题 190
第9章 排序 192
9.1 排序基本概念 192
9.2 插入排序 193
9.2.1 直接插入排序 193
9.2.2 折半插入排序 194
9.3 交换排序 195
9.3.1 冒泡排序 195
9.3.2 快速排序 198
9.4 选择排序 199
9.4.1 简单选择排序 199
9.4.2 堆排序 200
本章小结 204
习题 205
参考文献 207
1.1 数据结构的定义 1
1.1.1 逻辑结构 2
1.1.2 存储结构 6
1.1.3 数据运算 9
1.2 算法和算法分析 9
1.2.1 算法 9
1.2.2 算法分析 10
本章小结 14
习题 14
第2章 线性表 18
2.1 线性表的定义和操作 18
2.1.1 线性表的定义 18
2.1.2 线性表的基本操作 18
2.2 线性表的顺序表示 19
2.2.1 顺序表的定义 19
2.2.2 顺序表上基本操作的实现 20
2.3.3 顺序表的应用举例 25
2.3 线性表的链式表示 27
2.3.1 单链表的定义 27
2.3.2 单链表上基本操作的实现 28
2.3.3 单链表的应用举例 37
2.3.4 双链表 46
2.4 有序表 47
本章小结 50
习题 50
第3章 栈和队列 55
3.1 栈 55
3.1.1 栈的相关概念及基本运算 55
3.1.2 栈的顺序存储结构 56
3.1.3 栈的链式存储结构 59
3.1.4 栈的应用举例 66
3.2 队列 68
3.2.1 队列的相关概念及基本运算 68
3.2.2 队列的顺序存储结构 69
3.2.3 队列的链式存储结构 72
3.2.4 环形队列 77
3.2.5 队列的应用举例 80
本章小结 82
习题 82
第4章 串 85
4.1 串的基本概念及抽象数据类型基本运算 85
4.1.1 串的基本概念 85
4.1.2 串的抽象数据类型基本运算 85
4.2 串的存储结构及基本运算 86
4.2.1 串的顺序存储结构及基本运算 86
4.2.2 串的链式存储结构及基本运算 90
4.3 串的模式匹配 96
4.3.1 Brute Force算法 97
4.3.2 KMP算法 99
4.3.3 模式匹配的实际应用举例 102
本章小结 104
习题 104
第5章 数组和广义表 106
5.1 数组 106
5.1.1 数组的基本概念 106
5.1.2 数组的存储结构 106
5.2 矩阵的压缩存储 108
5.2.1 特殊矩阵 108
5.2.2 稀疏矩阵 110
5.3 广义表 113
5.3.1 广义表的定义 113
5.3.2 广义表的存储 115
5.3.3 广义表的运算 115
本章小结 118
习题 118
第6章 树和二叉树 119
6.1 树的基本概念 119
6.1.1 树的定义 119
6.1.2 树的基本术语 120
6.1.3 树的存储结构 121
6.1.4 树的遍历 123
6.2 二叉树 123
6.2.1 二叉树的定义 123
6.2.2 二叉树的性质 124
6.2.3 二叉树的存储结构 125
6.2.4 二叉树的基本运算及实现 127
6.3 遍历二叉树 129
6.4 二叉树与树、森林之间的转换 133
6.4.1 树、森林转换成二叉树 133
6.4.2 二叉树还原成树、森林 134
6.5 哈夫曼树及其应用 135
6.5.1 哈夫曼树的定义 135
6.5.2 哈夫曼树的构造 136
6.5.3 哈夫曼编码 138
本章小结 140
习题 140
第7章 图 142
7.1 图的定义和术语 142
7.1.1 图的定义 142
7.1.2 图的基本术语 142
7.2 图的存储结构 146
7.2.1 邻接矩阵 146
7.2.2 邻接表 147
7.3 图的遍历 148
7.3.1 深度优先搜索遍历 148
7.3.2 广度优先搜索遍历 150
7.4 最小生成树 151
7.4.1 生成树的相关概念 151
7.4.2 普里姆(Prim)算法 152
7.4.3 克鲁斯卡尔( Kruskal)算法 154
7.5 有向无环图的应用 158
7.5.1 拓扑排序 158
7.5.2 关键路径 159
7.6 最短路径 161
7.6.1 单源最短路径问题:Dijkstra算法 162
7.6.2 多源最短路径问题:Floyd算法 166
本章小结 171
习题 171
第8章 查找 173
8.1 查找的相关概念 173
8.2 线性表的查找 174
8.2.1 顺序查找 175
8.2.2 折半查找 175
8.2.3 分块查找 177
8.3 树表的查找 179
8.4 哈希表的查找 185
8.4.1 哈希表的相关概念 185
8.4.2 构造哈希函数的方法 186
8.4.3 处理冲突的方法 187
本章小结 190
习题 190
第9章 排序 192
9.1 排序基本概念 192
9.2 插入排序 193
9.2.1 直接插入排序 193
9.2.2 折半插入排序 194
9.3 交换排序 195
9.3.1 冒泡排序 195
9.3.2 快速排序 198
9.4 选择排序 199
9.4.1 简单选择排序 199
9.4.2 堆排序 200
本章小结 204
习题 205
参考文献 207