-
内容大纲
本书系统地介绍各种常用的数据结构以及查找和排序的各种算法,阐述各种数据结构的逻辑关系、存储表示及基本运算,并采用Python语言描述数据组织和算法实现。所有算法的程序均在Python 3.7中调试通过。
全书既注重原理又注重实践,配有大量图表和示例,内容丰富,概念讲解清楚,表达严谨,逻辑性强,语言精练,可读性好。书中提供了丰富的练习题、上机实验题和在线编程题,配套的《数据结构教程(Python语言描述)(第2版)学习与上机实验指导》详细地给出本书练习题的解题思路和参考答案、在线编程题代码和实验报告格式示例。
本书可作为高等学校计算机及相关专业“数据结构”课程教材,也可作为从事计算机软件开发和工程应用人员的参考书。 -
作者介绍
李春葆,武汉大学计算机学院教授。主要研究方向为数据挖掘和算法设计,先后主持和参加多个大型研究项目。主要为本科生讲授数据结构(15年以上)和软件工程等课程,为研究生讲授软件开发新技术、数据仓库与数据挖掘等课程,并出版十多部精品著作。 -
目录
第1章 绪论
1.1 什么是数据结构
1.1.1 数据结构的定义
1.1.2 数据的逻辑结构
1.1.3 数据的存储结构
1.1.4 数据的运算
1.1.5 数据结构和数据类型
1.2 算法及其描述
1.2.1 什么是算法
1.2.2 算法描述
1.3 Python简介
1.3.1 Python的标准数据类型
1.3.2 列表的复制
1.3.3 输入/输出和文件操作
1.3.4 Python程序设计
1.3.5 Python中变量的作用域和垃圾回收
1.4 算法分析
1.4.1 算法的设计目标
1.4.2 算法的时间性能分析
1.4.3 算法的存储空间分析
1.5 数据结构的目标
1.6 练习题
1.7 上机实验题
1.8 LeetCode在线编程题
第2章 线性表
2.1 线性表的定义
2.1.1 什么是线性表
2.1.2 线性表的抽象数据类型描述
2.2 线性表的顺序存储结构
2.2.1 顺序表
2.2.2 线性表的基本运算算法在顺序表中的实现
2.2.3 顺序表的应用算法设计示例
2.3 线性表的链式存储结构
2.3.1 链表
2.3.2 单链表
2.3.3 单链表的应用算法设计示例
2.3.4 双链表
2.3.5 双链表的应用算法设计示例
2.3.6 循环链表
2.4 顺序表和链表的比较
2.5 线性表的应用——两个多项式相加
2.5.1 问题描述
2.5.2 问题求解
2.6 练习题
2.7 上机实验题
2.7.1 基础实验题
2.7.2 应用实验题
2.8 LeetCode在线编程题
第3章 栈和队列
3.1 栈
3.1.1 栈的定义
3.1.2 栈的顺序存储结构及其基本运算算法的实现
3.1.3 顺序栈的应用算法设计示例
3.1.4 栈的链式存储结构及其基本运算算法的实现
3.1.5 链栈的应用算法设计示例
3.1.6 栈的综合应用
3.2 队列
3.2.1 队列的定义
3.2.2 队列的顺序存储结构及其基本运算算法的实现
3.2.3 循环队列的应用算法设计示例
3.2.4 队列的链式存储结构及其基本运算算法的实现
3.2.5 链队的应用算法设计示例
3.2.6 Python中的双端队列
3.2.7 队列的综合应用
3.2.8 优先队列
3.3 练习题
3.4 上机实验题
3.4.1 基础实验题
3.4.2 应用实验题
3.5 LeetCode在线编程题
第4章 串和数组
4.1 串
4.1.1 串的基本概念
4.1.2 串的存储结构
4.1.3 串的模式匹配
4.2 数组
4.2.1 数组的基本概念
4.2.2 特殊矩阵的压缩存储
4.2.3 稀疏矩阵
4.3 练习题
4.4 上机实验题
4.4.1 基础实验题
4.4.2 应用实验题
4.5 LeetCode在线编程题
第5章 递归
5.1 什么是递归
5.1.1 递归的定义
5.1.2 何时使用递归
5.1.3 递归模型
5.1.4 递归与数学归纳法
5.1.5 递归的执行过程
5.1.6 Python中递归函数的参数
5.1.7 递归算法的时空分析
5.2 递归算法的设计
5.2.1 递归算法设计的步骤
5.2.2 基于递归数据结构的递归算法设计
5.2.3 基于归纳方法的递归算法设计
5.3 练习题
5.4 上机实验题
5.4.1 基础实验题
5.4.2 应用实验题
5.5 LeetCode在线编程题
第6章 树和二叉树
6.1 树
6.1.1 树的定义
6.1.2 树的逻辑结构表示方法
6.1.3 树的基本术语
6.1.4 树的性质
6.1.5 树的基本运算
6.1.6 树的存储结构
6.2 二叉树
6.2.1 二叉树的概念
6.2.2 二叉树的性质
6.2.3 二叉树的存储结构
6.2.4 二叉树的递归算法设计
6.2.5 二叉树的基本运算算法及其实现
6.3 二叉树的先序、中序和后序遍历
6.3.1 二叉树遍历的概念
6.3.2 先序、中序和后序遍历的递归算法
6.3.3 递归遍历算法的应用
6.4 二叉树的层次遍历
6.4.1 层次遍历的过程
6.4.2 层次遍历算法的设计
6.4.3 层次遍历算法的应用
6.5 二叉树的构造
6.5.1 由先序/中序序列或后序/中序序列构造二叉树
*6.5.2 序列化和反序列化
6.6 线索二叉树
6.6.1 线索二叉树的定义
6.6.2 线索化二叉树
6.6.3 遍历线索二叉树
6.7 哈夫曼树
6.7.1 哈夫曼树的定义
6.7.2 哈夫曼树的构造算法
6.7.3 哈夫曼编码
6.8 二叉树与树、森林之间的转换
6.8.1 树到二叉树的转换及还原
6.8.2 森林到二叉树的转换及还原
*6.9 并查集
6.9.1 并查集的定义
6.9.2 并查集的实现
6.10 练习题
6.11 上机实验题
6.11.1 基础实验题
6.11.2 应用实验题
6.12 LeetCode在线编程题
第7章 图
7.1 图的基本概念
7.1.1 图的定义
7.1.2 图的基本术语
7.2 图的存储结构
7.2.1 邻接矩阵
7.2.2 邻接表
7.3 图的遍历
7.3.1 图遍历的概念
7.3.2 深度优先遍历
7.3.3 广度优先遍历
7.3.4 非连通图的遍历
7.4 图遍历算法的应用
7.4.1 深度优先遍历算法的应用
7.4.2 广度优先遍历算法的应用
7.5 生成树和最小生成树
7.5.1 生成树和最小生成树的概念
7.5.2 Prim算法
7.5.3 Kruskal算法
7.6 最短路径
7.6.1 最短路径的概念
7.6.2 Dijkstra算法
7.6.3 Floyd算法
7.7 拓扑排序
7.7.1 什么是拓扑排序
7.7.2 拓扑排序算法的设计
7.8 AOE网和关键路径
7.9 练习题
7.10 上机实验题
7.10.1 基础实验题
7.10.2 应用实验题
7.11 LeetCode在线编程题
第8章 查找
8.1 查找的基本概念
8.2 线性表的查找
8.2.1 顺序查找
8.2.2 折半查找
8.2.3 索引存储结构和分块查找
8.3 树表的查找
8.3.1 二叉排序树
8.3.2 平衡二叉树
8.3.3 B树
8.3.4 B+树
8.4 哈希表的查找
8.4.1 哈希表的基本概念
8.4.2 哈希函数的构造方法
8.4.3 哈希冲突的解决方法
8.4.4 哈希表的查找及性能分析
8.5 练习题
8.6 上机实验题
8.6.1 基础实验题
8.6.2 应用实验题
8.7 LeetCode在线编程题
第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.5 归并排序
9.5.1 自底向上的二路归并排序
9.5.2 自顶向下的二路归并排序
9.6 基数排序
9.7 各种内排序方法的比较和选择
9.8 外排序
9.8.1 生成初始归并段的方法
9.8.2 多路归并方法
9.9 练习题
9.10 上机实验题
9.10.1 基础实验题
9.10.2 应用实验题
9.11 LeetCode在线编程题
参考文献
同类热销排行榜
- C语言与程序设计教程(高等学校计算机类十二五规划教材)16
- 电机与拖动基础(教育部高等学校自动化专业教学指导分委员会规划工程应用型自动化专业系列教材)13.48
- 传感器与检测技术(第2版高职高专电子信息类系列教材)13.6
- ASP.NET项目开发实战(高职高专计算机项目任务驱动模式教材)15.2
- Access数据库实用教程(第2版十二五职业教育国家规划教材)14.72
- 信号与系统(第3版下普通高等教育九五国家级重点教材)15.08
- 电气控制与PLC(普通高等教育十二五电气信息类规划教材)17.2
- 数字电子技术基础(第2版)17.36
- VB程序设计及应用(第3版十二五职业教育国家规划教材)14.32
- Java Web从入门到精通(附光盘)/软件开发视频大讲堂27.92
推荐书目
-
孩子你慢慢来/人生三书 华人世界率性犀利的一枝笔,龙应台独家授权《孩子你慢慢来》20周年经典新版。她的《...
-
时间简史(插图版) 相对论、黑洞、弯曲空间……这些词给我们的感觉是艰深、晦涩、难以理解而且与我们的...
-
本质(精) 改革开放40年,恰如一部四部曲的年代大戏。技术突变、产品迭代、产业升级、资本对接...