数据结构-(第2版) 本书特色
本书是普通高等教育“十一五”***规划教材。全书共10章,内容包括:数据结构的概念,几种基本的线性结构(如线性表),栈和队列,串,几种非线性结构(如多维数组和广义表),树,图,常用的数据处理技术(如排序),查找,文件的存储结构和组织方法等。在每章中都收集了难度各异的习题和例题,全书采用c语言作为算法描述语言,并有详细的注释,书中全部程序均上机验证并调试通过,同时给出部分程序的运行结果。各章中的“简单应用举例”,既是本章算法的综合应用,也可作为本章实训内容和课程设计的综合练习,全书有很强的实用性和可操作性。
本书可以作为全日制高等学校计算机应用专业、微电子和信息工程专业、计算机信息管理和经济信息管理类等专业普通本科学生的专业基础课教材,也可以作为上述专业高职高专学生的参考教材,还可以作为计算机等级考试的参考书,供广大从事计算机应用工作的管理人员和技术人员学习参考。
数据结构-(第2版) 内容简介
本书是普通高等教育“十一五”***规划教材。书中全部程序均上机验证并调试通过。在每章中都收集了难度各异的习题和例题,有习题答案。各章中的“简单应用举例”有很强的实用性和可操作性。
数据结构-(第2版) 目录
第1章 概论 11.1 概述 11.2 数据结构的基本概念 41.2.1 数据结构的基本术语 41.2.2 数据的逻辑结构 61.2.3 数据的存储结构 81.3 算法性能分析与度量 121.3.1 算法和算法的描述方法 121.3.2 算法的特性 141.3.3 算法设计的要求 141.3.4 算法时间复杂度的分析与度量 151.3.5 算法存储空间的分析与度量 19本章小结 19习题1 20第2章 线性表 232.1 线性表的定义及基本运算 232.1.1 线性表的定义 232.1.2 线性表的基本运算 242.2 线性表的顺序存储结构及其运算 252.2.1 线性表的顺序存储结构 252.2.2 顺序表上的基本运算 262.2.3 顺序表上插入和删除运算的时间分析 302.2.4 顺序表的优点和缺点 312.3 线性表的链接存储结构及其运算 312.3.1 单链表 312.3.2 单链表上的基本运算 322.3.3 单链表上查找、插入和删除运算的时间分析 402.3.4 循环链表 402.3.5 双向链表 432.4 顺序表和链表的比较 462.5 线性表的简单应用举例 47本章小结 62习题2 63第3章 栈和队列 663.1 栈的基本概念 663.2 栈的存储结构 673.2.1 栈的顺序存储结构 673.2.2 栈的链接存储结构 683.2.3 栈的两种存储结构的比较 693.2.4 多个顺序栈共享一个数组的存储空间 693.3 栈的基本运算 703.3.1 顺序存储结构上顺序栈的运算实现 713.3.2 链接存储结构上链栈的运算实现 723.4 栈的简单应用举例 733.4.1 栈在递归过程中的作用 733.4.2 栈的几个简单应用实例 763.5 队列的基本概念 813.6 队列的存储结构 823.6.1 队列的顺序存储结构 823.6.2 顺序存储的循环队列 843.6.3 队列的链接存储结构 853.7 队列的基本运算 863.7.1 顺序存储结构上顺序队列的运算实现 863.7.2 顺序存储结构上循环队列的运算实现 873.7.3 链接存储结构上链队列的运算实现 893.8 队列的简单应用举例 91本章小结 97习题3 98第4章 串 1004.1 串的基本概念 1004.2 串的存储结构 1014.2.1 串的顺序存储结构 1014.2.2 串的链接存储结构 1034.3 串的基本运算及实现 1054.3.1 串的基本运算 1054.3.2 顺序串上基本运算的实现 1064.3.3 链串上基本运算的实现 1084.4 串的模式匹配运算 1124.4.1 bf模式匹配算法 1124.4.2 bm模式匹配算法 1154.4.3 kmp模式匹配算法 1174.5 串的简单应用举例 124本章小结 131习题4 131第5章 数组和广义表 1335.1 数组的概念和存储 1335.1.1 数组的概念 1335.1.2 数组的存储结构 1345.2 特殊矩阵的压缩存储 1375.2.1 对称矩阵的压缩存储 1375.2.2 三角矩阵的压缩存储 1385.2.3 对角矩阵的压缩存储 1395.3 稀疏矩阵的压缩存储 1415.3.1 稀疏矩阵的三元组表示 1415.3.2 稀疏矩阵的十字链表表示 1485.3.3 稀疏矩阵的简单应用举例 1525.4 广义表 1575.4.1 广义表的基本概念 1575.4.2 广义表的链接存储结构 1585.4.3 广义表的基本运算 1615.4.4 广义表的简单应用举例 166本章小结 167习题5 168第6章 树 1706.1 树的基本概念 1706.1.1 树的定义 1706.1.2 树的基本术语 1726.2 二叉树 1746.2.1 二叉树的概念 1746.2.2 二叉树的基本性质 1766.2.3 二叉树的存储结构 1776.3 二叉树的运算 1806.3.1 二叉树的遍历 1806.3.2 二叉树的建立 1856.3.3 二叉树的其他运算举例 1876.4 线索二叉树 1926.4.1 线索二叉树的概念 1926.4.2 二叉树的中序线索化 1936.4.3 线索二叉树的遍历和插入运算 1956.5 树和森林 1986.5.1 树的存储结构 1986.5.2 树和森林与二叉树的转换 2016.5.3 树的遍历 2056.5.4 森林的遍历 2066.6 哈夫曼树及其应用 2076.6.1 哈夫曼树的基本概念 2076.6.2 哈夫曼树的构造及实现 2086.6.3 哈夫曼编码 2116.6.4 哈夫曼译码 2156.6.5 哈夫曼树在编码问题中的完整程序 216本章小结 218习题6 219第7章 图 2227.1 图的基本概念 2227.1.1 图的实际背景 2227.1.2 图的定义 2237.1.3 图的基本术语 2247.2 图的存储结构 2277.2.1 邻接矩阵表示法 2277.2.2 邻接表表示法 2317.3 图的遍历 2347.3.1 连通图的深度优先搜索遍历 2357.3.2 连通图的广度优先搜索遍历 2377.3.3 非连通图的遍历 2407.3.4 连通图和非连通图的建立与遍历运算实例 2417.4 生成树和*小生成树 2437.4.1 生成树和*小生成树的概念 2447.4.2 kruskal算法 2457.4.3 prim算法 2487.5 *短路径 2507.5.1 *短路径的概念 2507.5.2 单源*短路径 2527.5.3 所有顶点对之间的*短路径 2557.6 aov网和拓扑排序 2607.6.1 aov网和拓扑排序的概念 2607.6.2 拓扑排序算法 2617.7 aoe网和关键路径 2657.7.1 aoe网和关键路径的概念 2657.7.2 关键路径的确定 2677.8 图的简单应用举例 269本章小结 277习题7 278第8章 排序 2818.1 排序的基本概念 2818.2 插入排序 2848.2.1 直接插入排序 2848.2.2 希尔排序 2868.3 交换排序 2888.3.1 冒泡排序 2888.3.2 快速排序 2918.4 选择排序 2948.4.1 直接选择排序 2948.4.2 堆排序 2958.5 归并排序 3028.5.1 两个相邻有序表的一次归并过程 3038.5.2 一趟归并排序过程 3038.5.3 二路归并排序 3048.6 各种内排序方法的比较和选择 3058.6.1 各种内排序方法的总结 3058.6.2 各种内排序方法的比较 3058.6.3 排序方法的选择 3068.7 排序的简单应用举例 307本章小结 311习题8 312第9章 查找 3159.1 查找的基本概念 3159.2 线性表的查找 3169.2.1 顺序查找 3169.2.2 二分查找 3179.2.3 分块查找 3209.3 树表的查找 3239.3.1 二叉排序树 3239.3.2 平衡的二叉排序树 3309.3.3 b-树 3359.4 散列表的查找 3429.4.1 散列表的概念 3429.4.2 散列函数的构造方法 3449.4.3 处理冲突的方法 3479.4.4 散列表的运算 3519.4.5 散列表的查找及分析 3559.5 查找的简单应用举例 357本章小结 362习题9 363第10章 文件 36510.1 文件的基本概念 36510.2 顺序文件 36710.3 索引文件 36810.4 索引顺序文件 37010.4.1 isam文件 37010.4.2 vsam文件 37310.5 散列文件 37510.6 多关键字文件 37610.6.1 多重表文件 37610.6.2 倒排文件 377本章小结 378习题10 379参考文献 380
数据结构-(第2版) 作者简介
田鲁怀,女,硕士学位,副教授职称。于1982年获中国石油大学(原华东石油学院)采油工程专业学士学位和1996年获上海大学(原上海工业大学)计算机应用专业硕士学位;先后在大学、高专学校和高职技术学院任教,分别于1989年和1996年获讲师和副教授职称。从1984年起,一直从事计算机专业的教学和科研工作。先后主讲了《数据结构》、《PASCAL语言程序设计》、《C语言程序设计》、《数据库原理及其应用》、《管理信息系统》等课程。