实用数据结构基础(第四版)
作者: 陈元春
出版时间:2015年9月
出版社:中国铁道出版社
- 中国铁道出版社
- 9787113207489
- 4版
- 137746
- 0040171521-4
- 16开
- 2015年9月
- 308
- 工学
- 软件工程
- TP311.12
- 计算机及相关专业
- 本科
本书集教学内容、习题、实验和课程设计于一体,书中的重要算法均给出了完整的C/C++语言源程序,并全部在VC++环境中运行通过,一书在手就能方便地进行“数据结构”课程的理论学习和实验、课程设计等实践性环节的训练。
本书适合作为高等院校计算机类专业数据结构课程的教材,也可以作为成人教育、自学考试和从事计算机应用的工程技术人员的参考用书。
第1章 绪论
1.1 什么是数据结构
1.1.1 从数据结构实验演示系统认识数据结构
1.1.2 数据结构研究的内容
1.2 数据的逻辑结构
1.2.1 基本概念
1.2.2 逻辑结构的描述
1.3 数据的存储结构
1.4 算法和算法的效率
1.4.1 算法
1.4.2 算法的效率
1.4.3 算法效率的评价
小结
实验
验证性实验1 数组、指针、结构体练习
自主设计实验1 学生成绩分析程序
习题1
第2章 线性表
2.1 线性表的定义与运算
2.1.1 线性表的定义
2.1.2 线性表的基本操作
2.2 线性表的顺序存储
2.2.1 顺序表
2.2.2 顺序表上基本运算的实現
2.3 线性表的链式存储
2.3.1 线性链表
2.3.2 线性链表上基本运算的实现
2.3.3 循环链表
2.3.4 双向链表
小结
实验
验证性实验2 线性表子系统
自主设计实验2 多项式求和
习题2
第3章 栈
3.1 栈的定义和运算
3.1.1 栈的定义和特性
3.1.2 栈的运算
3.2 栈的存储和实现
3.2.1 顺序栈
3.2.2 链栈
3.3 栈的应用举例
3.3.1 数制转换
3.3.2 表达式求值
3.3.3 子程序调用
3.3.4 递归调用
3.3.5 中断处理和现场保护
小结
实验
验证性实验3 栈子系统
自主设计实验3 后缀表达式求值
习题3
第4章 队列
4.1 队列的定义和运算
4.1.1 队列的定义和特性
4.1.2 队列的基本运算
4.2 队列的存储和实现
4.2.1 顺序队列
4.2.2 链队列
4.3 队列应用举例
小结
实验
验证性实验4 队列子系统
自主设计实验4 循环队列的实现和运算
习题4
第5章 串
5.1 串的定义和运算
5.1.1 串的定义
5.1.2 串的输入与输出
5.1.3 串的运算
5.2 串的表示和实现
5.2.1 定长顺序存储
5.2.2 链接存储
5.2.3 串的堆分配存储结构
5.3 串运算的实现
小结
实验
验证性实验5 串子系统
自主设计实验5 字符串分割处理
习题5
第6章 多维数组和广义表
6.1 多维数组
6.1.1 逻辑结构
6.1.2 存储结构
6.2 特殊矩阵的压缩存储
6.2.1 对称矩阵
6.2.2 三角矩阵
6.3 稀疏矩阵
6.3.1 稀疏矩阵的存储
6.3.2 稀疏矩阵的算法
6.4 广义表
6.4.1 广义表的定义和运算
6.4.2 广义表的首尾存储法
6.4.3 广义表的算法
小结
实验
验证性实验6 稀疏矩阵和广义表子系统
自主设计实验6 稀疏矩阵十字链表的存储
习题6
第7章 树和二叉树
7.1 树的定义和术语
7.1.1 树的定义及表示法
7.1.2 基本术语
7.2 二叉树
7.2.1 二叉树的定义
7.2.2 二叉树的性质
7.2.3 二叉树的存储
7.3 遍历二叉树和线索二叉树
7.3.1 遍历二叉树
7.3.2 恢复二叉树
7.3.3 线索二叉树
7.4 二叉树的转换
7.4.1 一般树转换为二叉树
7.4.2 森林转换为二叉树
7.4.3 叉树转换为树和森林
7.5 二叉树的应用
7.5.1 二叉树的基本应用
7.5.2 标识符树与表达式
7.6 哈夫曼树及其应用
7.6.1 哈夫曼树的引入
7.6.2 哈夫曼树的建立
7.6.3 哈夫曼编码
小结
实验
验证性实验7 二叉树子系统
自主设计实验7 标识符树与表达式求值
习题7
第8章 图
8.1 图的定义和基本操作
8.1.1 图的定义
8.1.2 图的相关术语
8.1.3 图的基本操作
8.2 图的存储表示
8.2.1 邻接矩阵
8.2.2 邻接表
8.2.3 十字链表
8.3 图的遍历
8.3.1 深度优先搜索
8.3.2 广度优先搜索
8.4 图的连通性
8.4.1 无向图的连通分量和生成树
8.4.2 最小生成树
8.5 最短路径
8.6 有向无环图及其应用
8.6.1 拓扑排序
8.6.2 关键路径
小结
实验
验证性实验8 图子系统
自主设计实验8 最小生成树
习题8
第9章 查找
9.1 查找的基本概念
9.2 静态查找表
9.2.1 顺序查找
9.2.2 二分查找
9.2.3 分块查找
9.3 动态查找表
9.3.1 二叉排序树
9.3.2 平衡二叉树
9.4 哈希表
9.4.1 哈希表与哈希方法
9.4.2 哈希函数的构造方法
9.4.3 处理冲突的方法
小结
实验
验证性实验9 查找子系统
自主设计实验9 哈希查找
习题9
第10章 排序
10.1 概述
10.2 插入排序
10.2.1 直接插入排序
10.2.2 二分插入排序
10.2.3 希尔排序
10.3 快速排序法
10.3.1 冒泡排序
10.3.2 快速排序
10.4 选择排序
10.4.1 简单选择排序
10.4.2 树形选择排序
10.4.3 堆排序
10.5 归并排序
10.6 各种排序方法的比较
小结
实验
验证性实验10 排序子系统
自主设计实验10 双向冒泡排序
习题10
第11章 数据结构课程设计
11.1 课程设计的目的与内容
11.1.1 课程设计的目的
11.1.2 课程设计的内容
11.1.3 课程设计报告
11.1.4 课程设计的考核
11.2 课程设计的要求
11.3 课程设计题目
课题1 多项式运算
课题2 浮点数的IEEE 754标准格式转换
课题3 稀疏矩阵的运算
课題4 非递归求解Hanoi问题
课题5 迷宮问题
课题6 非递归方式遍历二叉树
课题7 中缀表达式转后缀并求值
课题8 求字符串中最大长度的对称子串
课题9 二叉树的申序线索化及其非栈非递归遍历
课题10 求二叉树申任意两个结点间的距离
课題11 把二叉排序树转换成有序的双向链表
课题12 在二叉树中找出和为某一值的所有路径
课题13 判断整数序列是否为二叉排序树的后序遍历序列
课題14 有向无环图的判定及拓扑排序
课题15 求AOE网的关键路径
课题16 求有向图的强连通分量
课题17 基于十字链表有向图的遍历
课题18 求最小生成树
课题19 Dijkstra算法求最短路径
课题20 双拼输入法的快速定位
课题21 连通问题
课题22 哈希查找的实现与分析
课题23 文件记录读取并排序
课題24 平衡二叉树的构造及输出
课題25 马对棋盘方格的遍历
课题26 求两个字符串的扩展距离
课题27 求汽车最少加油次数问題
课题28 大整数运算
附录A 数据结构实验系统的组装
参考文献