数据结构实用教程(C语言版)(第二版) / 普通高等教育新工科电子信息类课改系列教材
¥38.00定价
作者: 王欣欣
出版时间:2023-04
出版社:西安电子科技大学出版社
- 西安电子科技大学出版社
- 9787560667720
- 2-1
- 514040
- 49242206-8
- 平装
- 16开
- 2023-04
- 315
- 216
- TP311.12
- 自动化技术、计算机技术
- 本科 高职
内容简介
本书系统地介绍了各种常用的数据结构与算法方面的基本知识,并使用C语言描述其算法,详细介绍了数据结构的C语言表示,及其在C语言程序中的应用,从而使学生在深刻理解和掌握数据结构的基础上,灵活运用C语言知识解决实际问题。
全书共8章,第1章介绍了数据结构与算法的一些基本概念;第2~6章分别讨论了线性表、栈和队列、串、树和二叉树、图等常用的数据结构及其应用;第7章和第8章分别介绍了查找和排序,它们都是广泛使用的数据处理技术。全书配有大量的例题和详尽的注释,各章都有不同类型的习题和实验,并配有可执行的C语言程序代码。本书的附录给出了各章习题答案与详解。
本书可作为应用型本科院校理工科相关专业学生的教材,也可作为高职高专和成人教育的教材,还可作为高等学校计算机专业硕士研究生入学考试的复习用书,对从事计算机系统软件、应用软件的设计与开发的人员及计算机编程爱好者也有很好的参考价值。
全书共8章,第1章介绍了数据结构与算法的一些基本概念;第2~6章分别讨论了线性表、栈和队列、串、树和二叉树、图等常用的数据结构及其应用;第7章和第8章分别介绍了查找和排序,它们都是广泛使用的数据处理技术。全书配有大量的例题和详尽的注释,各章都有不同类型的习题和实验,并配有可执行的C语言程序代码。本书的附录给出了各章习题答案与详解。
本书可作为应用型本科院校理工科相关专业学生的教材,也可作为高职高专和成人教育的教材,还可作为高等学校计算机专业硕士研究生入学考试的复习用书,对从事计算机系统软件、应用软件的设计与开发的人员及计算机编程爱好者也有很好的参考价值。
目录
第1章 绪论 1
1.1 什么是数据结构 1
1.2 基本概念和术语 3
1.3 抽象数据类型的表示与实现 5
1.4 算法和算法分析 7
1.4.1 算法的特性 7
1.4.2 算法设计的要求 8
1.4.3 算法的时间复杂度 8
1.5 算法与数据结构的C语言描述 9
1.5.1 指针变量 9
1.5.2 函数与参数传递 10
1.5.3 结构体 12
1.5.4 动态存储空间分配 14
小结 15
习题 15
实验 16
第2章 线性表 18
2.1 线性表的类型定义 18
2.1.1 线性表的逻辑结构 18
2.1.2 线性表的抽象数据类型 19
2.2 线性表的顺序表示和实现 20
2.3 线性表的链式表示和实现 27
2.3.1 单链表的定义 27
2.3.2 单链表基本操作实现 29
2.3.3 单链表应用举例 33
2.4 其他链表 35
2.4.1 双向链表 35
2.4.2 循环链表 37
2.5 线性表应用—— 一元多项式的表示和运算 38
小结 42
习题 42
实验 43
第3章 栈和队列 46
3.1 栈 46
3.1.1 栈的定义 46
3.1.2 栈的顺序存储结构的表示及实现 47
3.1.3 栈的链式存储结构的表示及实现 50
3.2 栈的应用举例 51
3.2.1 数制转换问题 52
3.2.2 利用栈实现迷宫求解 53
3.3 队列 57
3.3.1 队列的定义 57
3.3.2 队列的顺序存储结构 58
3.3.3 队列的链式存储结构 61
3.4 队列的应用举例 64
小结 67
习题 67
实验 68
第4章 串 71
4.1 串的定义 71
4.2 串的定长顺序存储表示和实现 74
4.3 串的堆分配存储表示和实现 76
4.4 串的操作应用——文本编辑 77
小结 77
习题 78
实验 79
第5章 树和二叉树 82
5.1 树的基本概念 82
5.1.1 树的定义 82
5.1.2 树的基本术语 86
5.2 二叉树 86
5.2.1 二叉树的定义 86
5.2.2 二叉树的性质 89
5.2.3 二叉树的存储结构 90
5.3 二叉树的遍历和线索二叉树 93
5.3.1 二叉树的遍历方法 93
5.3.2 遍历的应用举例 96
5.3.3 由遍历序列构造二叉树 96
5.3.4 线索二叉树 98
5.4 树和森林 100
5.4.1 树的存储结构 100
5.4.2 树与二叉树的转换 104
5.4.3 森林与二叉树的转换 104
5.4.4 树和森林的遍历 105
5.5 哈夫曼树 106
5.5.1 哈夫曼树的基本概念 106
5.5.2 哈夫曼树的构造方法 108
5.5.3 哈夫曼编码 110
小结 113
习题 113
实验 114
第6章 图 117
6.1 图的基本概念 117
6.1.1 图的定义 117
6.1.2 图的基本术语 118
6.1.3 图的抽象数据类型 119
6.2 图的存储结构 121
6.2.1 邻接矩阵 121
6.2.2 邻接表 122
6.2.3 十字链表 124
6.3 图的遍历 124
6.3.1 深度优先遍历 125
6.3.2 广度优先遍历 126
6.4 图的应用 127
6.4.1 最小生成树 127
6.4.2 拓扑排序 130
小结 131
习题 132
实验 133
第7章 查找 136
7.1 基本概念和术语 136
7.2 静态查找表 137
7.2.1 顺序查找 137
7.2.2 折半查找 138
7.2.3 索引顺序表的查找 141
7.3 哈希表 142
7.3.1 哈希表的基本概念 142
7.3.2 常用的哈希函数构造方法 142
7.3.3 处理冲突的方法 144
7.3.4 哈希表的查找及其分析 146
小结 147
习题 148
实验 149
第8章 排序 151
8.1 基本概念 151
8.2 插入排序 153
8.2.1 直接插入排序 153
8.2.2 折半插入排序 155
8.2.3 希尔排序 155
8.3 交换排序 157
8.3.1 冒泡排序 158
8.3.2 快速排序 159
8.4 选择排序 161
8.4.1 简单选择排序 161
8.4.2 树型选择排序 163
8.4.3 堆排序 163
8.5 2-路归并排序 166
8.6 各种内部排序算法性能的比较 168
小结 169
习题 169
实验 170
附录 习题答案及详解 173
参考文献 207
1.1 什么是数据结构 1
1.2 基本概念和术语 3
1.3 抽象数据类型的表示与实现 5
1.4 算法和算法分析 7
1.4.1 算法的特性 7
1.4.2 算法设计的要求 8
1.4.3 算法的时间复杂度 8
1.5 算法与数据结构的C语言描述 9
1.5.1 指针变量 9
1.5.2 函数与参数传递 10
1.5.3 结构体 12
1.5.4 动态存储空间分配 14
小结 15
习题 15
实验 16
第2章 线性表 18
2.1 线性表的类型定义 18
2.1.1 线性表的逻辑结构 18
2.1.2 线性表的抽象数据类型 19
2.2 线性表的顺序表示和实现 20
2.3 线性表的链式表示和实现 27
2.3.1 单链表的定义 27
2.3.2 单链表基本操作实现 29
2.3.3 单链表应用举例 33
2.4 其他链表 35
2.4.1 双向链表 35
2.4.2 循环链表 37
2.5 线性表应用—— 一元多项式的表示和运算 38
小结 42
习题 42
实验 43
第3章 栈和队列 46
3.1 栈 46
3.1.1 栈的定义 46
3.1.2 栈的顺序存储结构的表示及实现 47
3.1.3 栈的链式存储结构的表示及实现 50
3.2 栈的应用举例 51
3.2.1 数制转换问题 52
3.2.2 利用栈实现迷宫求解 53
3.3 队列 57
3.3.1 队列的定义 57
3.3.2 队列的顺序存储结构 58
3.3.3 队列的链式存储结构 61
3.4 队列的应用举例 64
小结 67
习题 67
实验 68
第4章 串 71
4.1 串的定义 71
4.2 串的定长顺序存储表示和实现 74
4.3 串的堆分配存储表示和实现 76
4.4 串的操作应用——文本编辑 77
小结 77
习题 78
实验 79
第5章 树和二叉树 82
5.1 树的基本概念 82
5.1.1 树的定义 82
5.1.2 树的基本术语 86
5.2 二叉树 86
5.2.1 二叉树的定义 86
5.2.2 二叉树的性质 89
5.2.3 二叉树的存储结构 90
5.3 二叉树的遍历和线索二叉树 93
5.3.1 二叉树的遍历方法 93
5.3.2 遍历的应用举例 96
5.3.3 由遍历序列构造二叉树 96
5.3.4 线索二叉树 98
5.4 树和森林 100
5.4.1 树的存储结构 100
5.4.2 树与二叉树的转换 104
5.4.3 森林与二叉树的转换 104
5.4.4 树和森林的遍历 105
5.5 哈夫曼树 106
5.5.1 哈夫曼树的基本概念 106
5.5.2 哈夫曼树的构造方法 108
5.5.3 哈夫曼编码 110
小结 113
习题 113
实验 114
第6章 图 117
6.1 图的基本概念 117
6.1.1 图的定义 117
6.1.2 图的基本术语 118
6.1.3 图的抽象数据类型 119
6.2 图的存储结构 121
6.2.1 邻接矩阵 121
6.2.2 邻接表 122
6.2.3 十字链表 124
6.3 图的遍历 124
6.3.1 深度优先遍历 125
6.3.2 广度优先遍历 126
6.4 图的应用 127
6.4.1 最小生成树 127
6.4.2 拓扑排序 130
小结 131
习题 132
实验 133
第7章 查找 136
7.1 基本概念和术语 136
7.2 静态查找表 137
7.2.1 顺序查找 137
7.2.2 折半查找 138
7.2.3 索引顺序表的查找 141
7.3 哈希表 142
7.3.1 哈希表的基本概念 142
7.3.2 常用的哈希函数构造方法 142
7.3.3 处理冲突的方法 144
7.3.4 哈希表的查找及其分析 146
小结 147
习题 148
实验 149
第8章 排序 151
8.1 基本概念 151
8.2 插入排序 153
8.2.1 直接插入排序 153
8.2.2 折半插入排序 155
8.2.3 希尔排序 155
8.3 交换排序 157
8.3.1 冒泡排序 158
8.3.2 快速排序 159
8.4 选择排序 161
8.4.1 简单选择排序 161
8.4.2 树型选择排序 163
8.4.3 堆排序 163
8.5 2-路归并排序 166
8.6 各种内部排序算法性能的比较 168
小结 169
习题 169
实验 170
附录 习题答案及详解 173
参考文献 207