数据结构——Java语言描述(第2版) / 21世纪高等学校规划教材·计算机科学与技术
¥39.50定价
作者: 朱战立
出版时间:2016-02
出版社:清华大学出版社
- 清华大学出版社
- 9787302423324
- 2-1
- 91870
- 44177983-2
- 平装
- 16开
- 2016-02
- 工学
- 软件工程
- TP311.12
- 计算机
- 本科
内容简介
朱战立编著的这本《数据结构--Java语言描述(第2版)》内容符合2009年公布的研究生新的入学统考大纲要求,内容主要包括线性表、堆栈、队列、串、数组、向量、集合、矩阵、树、二叉树、图、排序、查找、哈希表以及递归,对于每一种类型的数据结构,都详细阐述了基本概念、各种不同的存储结构和不同存储结构上一些主要操作的实现算法,并给出了许多设计实例帮助读者理解。面向对象方法是目前软件设计的主流方法,本书用面向对象思想组织全部材料,采用Java语言作为算法描述语言。
本书既可作为大专院校计算机等专业的教科书,也可作为从事计算机应用的工程技术人员的自学参考。
本书既可作为大专院校计算机等专业的教科书,也可作为从事计算机应用的工程技术人员的自学参考。
目录
第1章 绪论
1.1 数据结构的基本概念
1.2 抽象数据类型
1.3 算法和算法的时间复杂度
1.3.1 算法
1.3.2 算法设计目标
1.3.3 算法的时间复杂度分析
1.4 算法的空间复杂度分析
1.5 Java语言的工具包
习题
第2章 线性表
2.1 线性表概述
2.1.1 线性表的定义
2.1.2 线性表抽象数据类型
2.2 顺序表
2.2.1 顺序表存储结构
2.2.2 顺序表类
2.2.3 顺序表的效率分析
2.2.4 顺序表类应用举例
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.6 仿真链表
2.7 面向对象的软件设计方法
2.8 设计举例
2.8.1 顺序表算法设计举例
2.8.2 单链表算法设计举例
习题
第3章 堆栈和队列
3.1 堆栈
3.1.1 堆栈的基本概念
3.1.2 堆栈抽象数据类型
3.1.3 顺序堆栈
3.1.4 链式堆栈
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.6 队列的应用
3.4 优先级队列
3.4.1 顺序优先级队列类
3.4.2 优先级队列的应用
习题
第4章 串
4.1 串概述
4.1.1 串的基本概念
4.1.2 串的抽象数据类型
4.2 串的存储结构
4.3 串类
4.3.1 MyString类
4.3.2 MyString类的测试
4.3.3 MyStringBuffer类
4.3.4 MyStringBuffer类的测试
4.4 串的模式匹配算法
4.4.1 Brute-Force算法
4.4.2 KMP算法
4.4.3 Brute-Force算法和KMP算法的运行效率比较
习题
第5章 数组、集合和矩阵
5.1 数组
5.1.1 数组的定义
5.1.2 数组的实现机制
5.1.3 数组抽象数据类型
5.1.4 Java语言支持的数组功能
5.2 向量类
5.3 集合
5.3.1 集合的概念
5.3.2 集合抽象数据类型
5.3.3 集合类
5.4 矩阵类
5.5 特殊矩阵
5.5.1 特殊矩阵的压缩存储
5.5.2 n阶对称矩阵类
5.6 稀疏矩阵
5.6.1 稀疏矩阵的压缩存储
5.6.2 数组结构的稀疏矩阵类
5.6.3 三元组链表
习题
第6章 递归算法
6.1 递归的概念
6.2 递归算法的执行过程
6.3 递归算法的设计方法
6.4 递归过程和运行时栈
6.5 递归算法的效率分析
6.6 递归算法到非递归算法的转换
6.7 设计举例
6.7.1 一般递归函数设计举例
6.7.2 回溯法及设计举例
习题
第7章 树和二叉树
7.1 树
7.1.1 树的定义
7.1.2 树的表示方法
7.1.3 树的抽象数据类型
7.1.4 树的存储结构
7.2 二叉树
7.2.1 二叉树的定义
7.2.2 二叉树抽象数据类型
7.2.3 二叉树的性质
7.2.4 二叉树的存储结构
7.3 以结点类为基础的二叉树设计
7.3.1 二叉树结点类
7.3.2 二叉树的遍历
7.3.3 二叉树遍历的应用
7.3.4 应用举例
7.3.5 非递归的二叉树遍历算法
7.4 二叉树类
7.5 二叉树的分步遍历
7.5.1 二叉树游标类
7.5.2 二叉树中序游标类
7.5.3 二叉树层序游标类
7.6 线索二叉树
7.7 哈夫曼树
7.7.1 哈夫曼树的基本概念
7.7.2 哈夫曼编码问题
7.7.3 哈夫曼编码的软件设计
7.8 等价问题
7.9 树与二叉树的转换
7.10 树的遍历
习题
第8章 图
8.1 图概述
8.1.1 图的基本概念
8.1.2 图的抽象数据类型
8.2 图的存储结构
8.2.1 图的邻接矩阵存储结构
8.2.2 图的邻接表存储结构
8.3 邻接矩阵图类
8.4 图的遍历
8.4.1 图的深度和广度优先遍历算法
8.4.2 图的深度和广度优先遍历成员函数设计
8.5 最小生成树
8.5.1 最小生成树的基本概念
8.5.2 普里姆算法
8.5.3 克鲁斯卡尔算法
8.6 最短路径
8.6.1 最短路径的基本概念
8.6.2 从一个结点到其余各结点的最短路径
8.6.3 每对结点之间的最短路径
8.7 拓扑排序
8.8 关键路径
习题
第9章 排序
9.1 排序的基本概念
9.2 插入排序
9.2.1 直接插入排序
9.2.2 希尔排序
9.3 选择排序
9.3.1 直接选择排序
9.3.2 堆排序
9.4 交换排序
9.4.1 冒泡排序
9.4.2 快速排序
9.5 归并排序
9.6 基数排序
9.7 各种排序算法的性能比较
习题
第10章 查找
10.1 查找的基本概念
10.2 静态查找
10.2.1 在无序序列中查找
10.2.2 在有序序列中查找
10.2.3 索引
10.3 动态查找
10.3.1 二叉排序树
10.3.2 B_树
习题
第11章 哈希表
11.1 哈希表的基本概念
11.1.1 哈希表的基本构造方法
11.1.2 建立哈希表的关键问题
11.2 哈希函数构造方法
11.3 哈希冲突解决方法
11.3.1 开放定址法
11.3.2 链表法
11.4 哈希表类设计
11.4.1 哈希表项类
11.4.2 哈希表类
11.4.3 应用程序设计举例
习题
附录A Java语言工具包实现的常用数据结构
附录B 上机实习内容规范和实习报告范例
B.1 上机实习内容规范
B.2 上机实习报告范例——约瑟夫环问题
附录C 部分习题解答
参考文献
1.1 数据结构的基本概念
1.2 抽象数据类型
1.3 算法和算法的时间复杂度
1.3.1 算法
1.3.2 算法设计目标
1.3.3 算法的时间复杂度分析
1.4 算法的空间复杂度分析
1.5 Java语言的工具包
习题
第2章 线性表
2.1 线性表概述
2.1.1 线性表的定义
2.1.2 线性表抽象数据类型
2.2 顺序表
2.2.1 顺序表存储结构
2.2.2 顺序表类
2.2.3 顺序表的效率分析
2.2.4 顺序表类应用举例
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.6 仿真链表
2.7 面向对象的软件设计方法
2.8 设计举例
2.8.1 顺序表算法设计举例
2.8.2 单链表算法设计举例
习题
第3章 堆栈和队列
3.1 堆栈
3.1.1 堆栈的基本概念
3.1.2 堆栈抽象数据类型
3.1.3 顺序堆栈
3.1.4 链式堆栈
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.6 队列的应用
3.4 优先级队列
3.4.1 顺序优先级队列类
3.4.2 优先级队列的应用
习题
第4章 串
4.1 串概述
4.1.1 串的基本概念
4.1.2 串的抽象数据类型
4.2 串的存储结构
4.3 串类
4.3.1 MyString类
4.3.2 MyString类的测试
4.3.3 MyStringBuffer类
4.3.4 MyStringBuffer类的测试
4.4 串的模式匹配算法
4.4.1 Brute-Force算法
4.4.2 KMP算法
4.4.3 Brute-Force算法和KMP算法的运行效率比较
习题
第5章 数组、集合和矩阵
5.1 数组
5.1.1 数组的定义
5.1.2 数组的实现机制
5.1.3 数组抽象数据类型
5.1.4 Java语言支持的数组功能
5.2 向量类
5.3 集合
5.3.1 集合的概念
5.3.2 集合抽象数据类型
5.3.3 集合类
5.4 矩阵类
5.5 特殊矩阵
5.5.1 特殊矩阵的压缩存储
5.5.2 n阶对称矩阵类
5.6 稀疏矩阵
5.6.1 稀疏矩阵的压缩存储
5.6.2 数组结构的稀疏矩阵类
5.6.3 三元组链表
习题
第6章 递归算法
6.1 递归的概念
6.2 递归算法的执行过程
6.3 递归算法的设计方法
6.4 递归过程和运行时栈
6.5 递归算法的效率分析
6.6 递归算法到非递归算法的转换
6.7 设计举例
6.7.1 一般递归函数设计举例
6.7.2 回溯法及设计举例
习题
第7章 树和二叉树
7.1 树
7.1.1 树的定义
7.1.2 树的表示方法
7.1.3 树的抽象数据类型
7.1.4 树的存储结构
7.2 二叉树
7.2.1 二叉树的定义
7.2.2 二叉树抽象数据类型
7.2.3 二叉树的性质
7.2.4 二叉树的存储结构
7.3 以结点类为基础的二叉树设计
7.3.1 二叉树结点类
7.3.2 二叉树的遍历
7.3.3 二叉树遍历的应用
7.3.4 应用举例
7.3.5 非递归的二叉树遍历算法
7.4 二叉树类
7.5 二叉树的分步遍历
7.5.1 二叉树游标类
7.5.2 二叉树中序游标类
7.5.3 二叉树层序游标类
7.6 线索二叉树
7.7 哈夫曼树
7.7.1 哈夫曼树的基本概念
7.7.2 哈夫曼编码问题
7.7.3 哈夫曼编码的软件设计
7.8 等价问题
7.9 树与二叉树的转换
7.10 树的遍历
习题
第8章 图
8.1 图概述
8.1.1 图的基本概念
8.1.2 图的抽象数据类型
8.2 图的存储结构
8.2.1 图的邻接矩阵存储结构
8.2.2 图的邻接表存储结构
8.3 邻接矩阵图类
8.4 图的遍历
8.4.1 图的深度和广度优先遍历算法
8.4.2 图的深度和广度优先遍历成员函数设计
8.5 最小生成树
8.5.1 最小生成树的基本概念
8.5.2 普里姆算法
8.5.3 克鲁斯卡尔算法
8.6 最短路径
8.6.1 最短路径的基本概念
8.6.2 从一个结点到其余各结点的最短路径
8.6.3 每对结点之间的最短路径
8.7 拓扑排序
8.8 关键路径
习题
第9章 排序
9.1 排序的基本概念
9.2 插入排序
9.2.1 直接插入排序
9.2.2 希尔排序
9.3 选择排序
9.3.1 直接选择排序
9.3.2 堆排序
9.4 交换排序
9.4.1 冒泡排序
9.4.2 快速排序
9.5 归并排序
9.6 基数排序
9.7 各种排序算法的性能比较
习题
第10章 查找
10.1 查找的基本概念
10.2 静态查找
10.2.1 在无序序列中查找
10.2.2 在有序序列中查找
10.2.3 索引
10.3 动态查找
10.3.1 二叉排序树
10.3.2 B_树
习题
第11章 哈希表
11.1 哈希表的基本概念
11.1.1 哈希表的基本构造方法
11.1.2 建立哈希表的关键问题
11.2 哈希函数构造方法
11.3 哈希冲突解决方法
11.3.1 开放定址法
11.3.2 链表法
11.4 哈希表类设计
11.4.1 哈希表项类
11.4.2 哈希表类
11.4.3 应用程序设计举例
习题
附录A Java语言工具包实现的常用数据结构
附录B 上机实习内容规范和实习报告范例
B.1 上机实习内容规范
B.2 上机实习报告范例——约瑟夫环问题
附录C 部分习题解答
参考文献