
微信扫一扫,移动浏览光盘
简介
本书特色:
◆内容组织上层次分明,结构清晰。内容叙述深入浅出,表述严谨。强调实验动手能力的提高,每章给出与内容相一致的上机实验题。与本书配套的《数据结构教程学习指导》和《数据结构教程上机实验指导》两书,构成一个完整的教学系列。
◆本系列中所有程序均在Visual C++6.0环境下调试通过。本教程和相关学习指导的编写得到武汉大学教务部“数据结构综合教学改革”和“数据结构精品课程建设”教学项目的支持,是集体课程组许多教师多年来数据结构课程教学研究和教学改革经验和成果于一体。
◆书中精编了大量的实例,这些实例体现了良好的程序设计风格。
本书介绍了数据结构的基本知识和各种数据结构的具体应用。
全书分为14章,主要内容包括数据结构的基本概念、线性表、栈和队列、串、数组和稀疏矩阵、递归算法、树和二叉树、广义表、图、各种查找算法的实现、排序算法的实现,文件结构以及采用面向对象方法描述算法等。
本书突出上机实习内容,第1~13章给出大量的上机实验题,供读者选用。书中精编了大量的实例,这些实例体现了求解问题的方法和良好的程序设计风格。
本书适合作为高等院校计算机及其相关专业的本科生教材,也可作为软件技术人员的参考用书。
目录
第1章 绪论
1.1 数据结构
1.1.1 数据结构的定义
1.1.2 逻辑结构类型
1.1.3 存储结构类型
1.1.4 数据结构和数据类型
1.2 算法及其描述
1.2.1 算法
1.2.2 算法描述
1.3 算法分析
1.3.1 算法设计的目标
1.3.2 算法效率分析
1.3.3 算法存储空间分析
1.4 小结
1.5 习题
1.6 上机实验题
第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.3.5 静态链表
2.4 线性表的应用
2.5 有序表
2.6 小结
2.7 习题
2.8 上机实验题
第3章 栈和队列
3.1 栈
3.1.1 栈的定义
3.1.2 栈的顺序存储结构及其基本运算的实现
3.1.3 栈的链式存储结构及其基本运算的实现
3.1.4 栈的应用举例
3.2 队列
3.2.1 队列的定义
3.2.2 队列的顺序存储结构及其基本运算的实现
3.2.3 队列的链式存储结构及其基本运算的实现
3.2.4 队列的应用举例
3.3 小结
3.4 习题
3.5 上机实验题
第4章 串
4.1 串的基本概念
4.2 串的存储结构
4.2.1 串的顺序存储结构——顺序串
4.2.2 串的链式存储结构——链串
4.3 串的模式匹配
4.3.1 Brute-Force算法
4.3.2 KMP算法
4.4 小结
4.5 习题
4.6 上机实验题
第5章 数组和稀疏矩阵
5.1 数组
5.1.1 数组的基本概念
5.1.2 数组的存储结构
5.1.3 特殊矩阵的压缩存储
5.2 稀疏矩阵
5.2.1 稀疏矩阵的三元组表示
5.2.2 稀疏矩阵的十字链表表示
5.3 小结
5.4 习题
5.5 上机实验题
第6章 递归
6.1 什么是递归
6.1.1 递归的定义
6.1.2 何时使用递归
6.1.3 递归模型
6.1.4 递归与数学归纳法
6.2 递归调用的实现原理
6.3 递归算法的设计
6.4 递归算法到非递归算法的转换
6.4.1 尾递归和单向递归的消除
6.4.2 模拟系统运行时的栈消除递归
6.5 小结
6.6 习题
6.7 上机实验题
第7章 树形结构
7.1 树的基本概念
7.1.1 树的定义
7.1.2 树的逻辑表示方法
7.1.3 树的基本术语
7.1.4 树的性质
7.1.5 树的基本运算
7.1.6 树的存储结构
7.2 二叉树概念和性质
7.2.1 二叉树概念
7.2.2 二叉树性质
7.2.3 二叉树与树、森林之间的转换
7.3 二叉树存储结构
7.3.1 二叉树的顺序存储结构
7.3.2 二叉树的链式存储结构
7.4 二叉树的遍历
7.4.1 二叉树遍历的概念
7.4.2 二叉树遍历递归算法
7.4.3 二叉树遍历非递归算法
7.5 二叉树的基本运算及其实现
7.5.1 二叉树的基本运算
7.5.2 二叉树的基本运算算法实现
7.6 二叉树的构造
7.7 线索二叉树
7.7.1 线索二叉树的概念
7.7.2 线索化二叉树
7.7.3 遍历线索化二叉树
7.8 哈夫曼树
7.8.1 哈夫曼树概述
7.8.2 哈夫曼树的构造算法
7.8.3 哈夫曼编码
7.9 小结
7.10 习题
7.11 上机实验题
第8章 广义表
8.1 广义表的定义
8.2 广义表的存储结构
8.3 广义表的运算
8.4 小结
8.5 习题
8.6 上机实验题
第9章 图
9.1 图的基本概念
9.1.1 图的定义
9.1.2 图的基本术语
9.2 图的存储结构
9.2.1 邻接矩阵存储方法
9.2.2 邻接表存储方法
9.2.3 十字邻接表存储方法
9.2.4 邻接多重表存储方法
9.3 图的遍历
9.3.1 图的遍历的概念
9.3.2 深度优先搜索遍历
9.3.3 广度优先搜索遍历
9.3.4 非连通图的遍历
9.4 生成树和最小生成树
9.4.1 生成树的概念
9.4.2 无向图的连通分量和生成树
9.4.3 有向图的强连通分量
9.4.4 普里姆算法
9.4.5 克鲁斯卡尔算法
9.5 最短路径
9.5.1 路径的概念
9.5.2 从一个顶点到其余各顶点的最短路径
9.5.3 每对顶点之间的最短路径
9.6 拓扑排序
9.7 AOE网与关键路径
9.8 小结
9.9 习题
9.10 上机实验题
第10章 查找
10.1 查找的基本概念
10.2 线性表的查找
10.2.1 顺序查找
10.2.2 二分查找
10.2.3 分块查找
10.3 树表的查找
10.3.1 二叉排序树
10.3.2 平衡二叉树
10.3.3 B-树
10.3.4 B+树
10.4 哈希表查找
10.4.1 哈希表的基本概念
10.4.2 哈希函数构造方法
10.4.3 哈希冲突解决方法
10.4.4 哈希表上的运算
10.5 小结
10.6 习题
10.7 上机实验题
第11章 内排序
11.1 排序的基本概念
11.2 插入排序
11.2.1 直接插入排序
11.2.2 希尔排序
11.3 交换排序
11.3.1 冒泡排序
11.3.2 快速排序
11.4 选择排序
11.4.1 直接选择排序
11.4.2 堆排序
11.5 归并排序
11.6 基数排序
11.7 各种内排序方法的比较和选择
11.8 小结
11.9 习题
11.10 上机实验题
第12章 外排序
12.1 外排序概述
12.2 磁盘排序
12.2.1 磁盘排序过程
12.2.2 多路平衡归并
12.2.3 初始归并段的生成
12.2.4 最佳归并树
12.3 磁带排序
12.3.1 多路平衡归并排序
12.3.2 多阶段归并排序
12.4 小结
12.5 习题
12.6 上机实验题
第13章 文件
13.1 文件的基本概念
13.1.1 文件
13.1.2 文件的逻辑结构及操作
13.1.3 文件的存储结构
13.2 顺序文件
13.3 索引文件
13.3.1 ISAM文件
13.3.2 VSAM文件
13.4 哈希文件
13.5 多关键字文件
13.5.1 多重表文件
13.5.2 倒排文件
13.6 小结
13.7 习题
13.8 上机实验题
第14章 采用面向对象的方法描述算法
14.1 面向对象的概念
14.2 用C++描述面向对象的程序
14.2.1 类
14.2.2 类对象
14.2.3 构造函数和析构函数
14.2.4 派生类
14.3 用C++描述数据结构算法
14.3.1 顺序表类
14.3.2 链栈类
14.3.3 二叉树类
附录A 综合实验题
附录B 实验报告格式
参考文献
1.1 数据结构
1.1.1 数据结构的定义
1.1.2 逻辑结构类型
1.1.3 存储结构类型
1.1.4 数据结构和数据类型
1.2 算法及其描述
1.2.1 算法
1.2.2 算法描述
1.3 算法分析
1.3.1 算法设计的目标
1.3.2 算法效率分析
1.3.3 算法存储空间分析
1.4 小结
1.5 习题
1.6 上机实验题
第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.3.5 静态链表
2.4 线性表的应用
2.5 有序表
2.6 小结
2.7 习题
2.8 上机实验题
第3章 栈和队列
3.1 栈
3.1.1 栈的定义
3.1.2 栈的顺序存储结构及其基本运算的实现
3.1.3 栈的链式存储结构及其基本运算的实现
3.1.4 栈的应用举例
3.2 队列
3.2.1 队列的定义
3.2.2 队列的顺序存储结构及其基本运算的实现
3.2.3 队列的链式存储结构及其基本运算的实现
3.2.4 队列的应用举例
3.3 小结
3.4 习题
3.5 上机实验题
第4章 串
4.1 串的基本概念
4.2 串的存储结构
4.2.1 串的顺序存储结构——顺序串
4.2.2 串的链式存储结构——链串
4.3 串的模式匹配
4.3.1 Brute-Force算法
4.3.2 KMP算法
4.4 小结
4.5 习题
4.6 上机实验题
第5章 数组和稀疏矩阵
5.1 数组
5.1.1 数组的基本概念
5.1.2 数组的存储结构
5.1.3 特殊矩阵的压缩存储
5.2 稀疏矩阵
5.2.1 稀疏矩阵的三元组表示
5.2.2 稀疏矩阵的十字链表表示
5.3 小结
5.4 习题
5.5 上机实验题
第6章 递归
6.1 什么是递归
6.1.1 递归的定义
6.1.2 何时使用递归
6.1.3 递归模型
6.1.4 递归与数学归纳法
6.2 递归调用的实现原理
6.3 递归算法的设计
6.4 递归算法到非递归算法的转换
6.4.1 尾递归和单向递归的消除
6.4.2 模拟系统运行时的栈消除递归
6.5 小结
6.6 习题
6.7 上机实验题
第7章 树形结构
7.1 树的基本概念
7.1.1 树的定义
7.1.2 树的逻辑表示方法
7.1.3 树的基本术语
7.1.4 树的性质
7.1.5 树的基本运算
7.1.6 树的存储结构
7.2 二叉树概念和性质
7.2.1 二叉树概念
7.2.2 二叉树性质
7.2.3 二叉树与树、森林之间的转换
7.3 二叉树存储结构
7.3.1 二叉树的顺序存储结构
7.3.2 二叉树的链式存储结构
7.4 二叉树的遍历
7.4.1 二叉树遍历的概念
7.4.2 二叉树遍历递归算法
7.4.3 二叉树遍历非递归算法
7.5 二叉树的基本运算及其实现
7.5.1 二叉树的基本运算
7.5.2 二叉树的基本运算算法实现
7.6 二叉树的构造
7.7 线索二叉树
7.7.1 线索二叉树的概念
7.7.2 线索化二叉树
7.7.3 遍历线索化二叉树
7.8 哈夫曼树
7.8.1 哈夫曼树概述
7.8.2 哈夫曼树的构造算法
7.8.3 哈夫曼编码
7.9 小结
7.10 习题
7.11 上机实验题
第8章 广义表
8.1 广义表的定义
8.2 广义表的存储结构
8.3 广义表的运算
8.4 小结
8.5 习题
8.6 上机实验题
第9章 图
9.1 图的基本概念
9.1.1 图的定义
9.1.2 图的基本术语
9.2 图的存储结构
9.2.1 邻接矩阵存储方法
9.2.2 邻接表存储方法
9.2.3 十字邻接表存储方法
9.2.4 邻接多重表存储方法
9.3 图的遍历
9.3.1 图的遍历的概念
9.3.2 深度优先搜索遍历
9.3.3 广度优先搜索遍历
9.3.4 非连通图的遍历
9.4 生成树和最小生成树
9.4.1 生成树的概念
9.4.2 无向图的连通分量和生成树
9.4.3 有向图的强连通分量
9.4.4 普里姆算法
9.4.5 克鲁斯卡尔算法
9.5 最短路径
9.5.1 路径的概念
9.5.2 从一个顶点到其余各顶点的最短路径
9.5.3 每对顶点之间的最短路径
9.6 拓扑排序
9.7 AOE网与关键路径
9.8 小结
9.9 习题
9.10 上机实验题
第10章 查找
10.1 查找的基本概念
10.2 线性表的查找
10.2.1 顺序查找
10.2.2 二分查找
10.2.3 分块查找
10.3 树表的查找
10.3.1 二叉排序树
10.3.2 平衡二叉树
10.3.3 B-树
10.3.4 B+树
10.4 哈希表查找
10.4.1 哈希表的基本概念
10.4.2 哈希函数构造方法
10.4.3 哈希冲突解决方法
10.4.4 哈希表上的运算
10.5 小结
10.6 习题
10.7 上机实验题
第11章 内排序
11.1 排序的基本概念
11.2 插入排序
11.2.1 直接插入排序
11.2.2 希尔排序
11.3 交换排序
11.3.1 冒泡排序
11.3.2 快速排序
11.4 选择排序
11.4.1 直接选择排序
11.4.2 堆排序
11.5 归并排序
11.6 基数排序
11.7 各种内排序方法的比较和选择
11.8 小结
11.9 习题
11.10 上机实验题
第12章 外排序
12.1 外排序概述
12.2 磁盘排序
12.2.1 磁盘排序过程
12.2.2 多路平衡归并
12.2.3 初始归并段的生成
12.2.4 最佳归并树
12.3 磁带排序
12.3.1 多路平衡归并排序
12.3.2 多阶段归并排序
12.4 小结
12.5 习题
12.6 上机实验题
第13章 文件
13.1 文件的基本概念
13.1.1 文件
13.1.2 文件的逻辑结构及操作
13.1.3 文件的存储结构
13.2 顺序文件
13.3 索引文件
13.3.1 ISAM文件
13.3.2 VSAM文件
13.4 哈希文件
13.5 多关键字文件
13.5.1 多重表文件
13.5.2 倒排文件
13.6 小结
13.7 习题
13.8 上机实验题
第14章 采用面向对象的方法描述算法
14.1 面向对象的概念
14.2 用C++描述面向对象的程序
14.2.1 类
14.2.2 类对象
14.2.3 构造函数和析构函数
14.2.4 派生类
14.3 用C++描述数据结构算法
14.3.1 顺序表类
14.3.2 链栈类
14.3.3 二叉树类
附录A 综合实验题
附录B 实验报告格式
参考文献
数据结构教程[电子资源.图书]
- 名称
- 类型
- 大小
光盘服务联系方式: 020-38250260 客服QQ:4006604884
云图客服:
用户发送的提问,这种方式就需要有位在线客服来回答用户的问题,这种 就属于对话式的,问题是这种提问是否需要用户登录才能提问
Video Player
×
Audio Player
×
pdf Player
×
