欢迎光临
免费的PDF电子书下载网站

数据结构(第2版) PDF下载

编辑推荐

本书是普通高等教育“十一五”***规划教材。书中全部程序均上机验证并调试通过。在每章中都收集了难度各异的习题和例题,有习题答案。各章中的“简单应用举例”有很强的实用性和可操作性。 ;

内容简介

本书是普通高等教育“十一五”***规划教材。全书共10章,内容包括:数据结构的概念,几种基本的线性结构(如线性表),栈和队列,串,几种非线性结构(如多维数组和广义表),树,图,常用的数据处理技术(如排序),查找,文件的存储结构和组织方法等。在每章中都收集了难度各异的习题和例题,全书采用C语言作为算法描述语言,并有详细的注释,书中全部程序均上机验证并调试通过,同时给出部分程序的运行结果。各章中的“简单应用举例”,既是本章算法的综合应用,也可作为本章实训内容和课程设计的综合练习,全书有很强的实用性和可操作性。

本书可以作为全日制高等学校计算机应用专业、微电子和信息工程专业、计算机信息管理和经济信息管理类等专业普通本科学生的专业基础课教材,也可以作为上述专业高职高专学生的参考教材,还可以作为计算机等级考试的参考书,供广大从事计算机应用工作的管理人员和技术人员学习参考。

作者简介

田鲁怀,女,硕士学位,副教授职称。于1982年获中国石油大学(原华东石油学院)采油工程专业学士学位和1996年获上海大学(原上海工业大学)计算机应用专业硕士学位;先后在大学、高专学校和高职技术学院任教,分别于1989年和1996年获讲师和副教授职称。从1984年起,一直从事计算机专业的教学和科研工作。先后主讲了《数据结构》、《PASCAL语言程序设计》、《C语言程序设计》、《数据库原理及其应用》、《管理信息系统》等课程。

数据结构(第2版) PDF下载

目录

第1章 概论 1
1.1 概述 1
1.2 数据结构的基本概念 4
1.2.1 数据结构的基本术语 4
1.2.2 数据的逻辑结构 6
1.2.3 数据的存储结构 8
1.3 算法性能分析与度量 12
1.3.1 算法和算法的描述方法 12
1.3.2 算法的特性 14
1.3.3 算法设计的要求 14
1.3.4 算法时间复杂度的分析与度量 15
1.3.5 算法存储空间的分析与度量 19
本章小结 19
习题1 20
第2章 线性表 23
2.1 线性表的定义及基本运算 23
2.1.1 线性表的定义 23
2.1.2 线性表的基本运算 24
2.2 线性表的顺序存储结构及其运算 25
2.2.1 线性表的顺序存储结构 25
2.2.2 顺序表上的基本运算 26
2.2.3 顺序表上插入和删除运算的时间分析 30
2.2.4 顺序表的优点和缺点 31
2.3 线性表的链接存储结构及其运算 31
2.3.1 单链表 31
2.3.2 单链表上的基本运算 32
2.3.3 单链表上查找、插入和删除运算的时间分析 40
2.3.4 循环链表 40
2.3.5 双向链表 43
2.4 顺序表和链表的比较 46
2.5 线性表的简单应用举例 47
本章小结 62
习题2 63
第3章 栈和队列 66
3.1 栈的基本概念 66
3.2 栈的存储结构 67
3.2.1 栈的顺序存储结构 67
3.2.2 栈的链接存储结构 68
3.2.3 栈的两种存储结构的比较 69
3.2.4 多个顺序栈共享一个数组的存储空间 69
3.3 栈的基本运算 70
3.3.1 顺序存储结构上顺序栈的运算实现 71
3.3.2 链接存储结构上链栈的运算实现 72
3.4 栈的简单应用举例 73
3.4.1 栈在递归过程中的作用 73
3.4.2 栈的几个简单应用实例 76
3.5 队列的基本概念 81
3.6 队列的存储结构 82
3.6.1 队列的顺序存储结构 82
3.6.2 顺序存储的循环队列 84
3.6.3 队列的链接存储结构 85
3.7 队列的基本运算 86
3.7.1 顺序存储结构上顺序队列的运算实现 86
3.7.2 顺序存储结构上循环队列的运算实现 87
3.7.3 链接存储结构上链队列的运算实现 89
3.8 队列的简单应用举例 91
本章小结 97
习题3 98
第4章 串 100
4.1 串的基本概念 100
4.2 串的存储结构 101
4.2.1 串的顺序存储结构 101
4.2.2 串的链接存储结构 103
4.3 串的基本运算及实现 105
4.3.1 串的基本运算 105
4.3.2 顺序串上基本运算的实现 106
4.3.3 链串上基本运算的实现 108
4.4 串的模式匹配运算 112
4.4.1 BF模式匹配算法 112
4.4.2 BM模式匹配算法 115
4.4.3 KMP模式匹配算法 117
4.5 串的简单应用举例 124
本章小结 131
习题4 131

第5章 数组和广义表 133
5.1 数组的概念和存储 133
5.1.1 数组的概念 133
5.1.2 数组的存储结构 134
5.2 特殊矩阵的压缩存储 137
5.2.1 对称矩阵的压缩存储 137
5.2.2 三角矩阵的压缩存储 138
5.2.3 对角矩阵的压缩存储 139
5.3 稀疏矩阵的压缩存储 141
5.3.1 稀疏矩阵的三元组表示 141
5.3.2 稀疏矩阵的十字链表表示 148
5.3.3 稀疏矩阵的简单应用举例 152
5.4 广义表 157
5.4.1 广义表的基本概念 157
5.4.2 广义表的链接存储结构 158
5.4.3 广义表的基本运算 161
5.4.4 广义表的简单应用举例 166
本章小结 167
习题5 168
第6章 树 170
6.1 树的基本概念 170
6.1.1 树的定义 170
6.1.2 树的基本术语 172
6.2 二叉树 174
6.2.1 二叉树的概念 174
6.2.2 二叉树的基本性质 176
6.2.3 二叉树的存储结构 177
6.3 二叉树的运算 180
6.3.1 二叉树的遍历 180
6.3.2 二叉树的建立 185
6.3.3 二叉树的其他运算举例 187
6.4 线索二叉树 192
6.4.1 线索二叉树的概念 192
6.4.2 二叉树的中序线索化 193
6.4.3 线索二叉树的遍历和插入运算 195
6.5 树和森林 198
6.5.1 树的存储结构 198
6.5.2 树和森林与二叉树的转换 201
6.5.3 树的遍历 205
6.5.4 森林的遍历 206
6.6 哈夫曼树及其应用 207
6.6.1 哈夫曼树的基本概念 207
6.6.2 哈夫曼树的构造及实现 208
6.6.3 哈夫曼编码 211
6.6.4 哈夫曼译码 215
6.6.5 哈夫曼树在编码问题中的完整程序 216
本章小结 218
习题6 219
第7章 图 222
7.1 图的基本概念 222
7.1.1 图的实际背景 222
7.1.2 图的定义 223
7.1.3 图的基本术语 224
7.2 图的存储结构 227
7.2.1 邻接矩阵表示法 227
7.2.2 邻接表表示法 231
7.3 图的遍历 234
7.3.1 连通图的深度优先搜索遍历 235
7.3.2 连通图的广度优先搜索遍历 237
7.3.3 非连通图的遍历 240
7.3.4 连通图和非连通图的建立与遍历运算实例 241
7.4 生成树和*小生成树 243
7.4.1 生成树和*小生成树的概念 244
7.4.2 Kruskal算法 245
7.4.3 Prim算法 248
7.5 *短路径 250
7.5.1 *短路径的概念 250
7.5.2 单源*短路径 252
7.5.3 所有顶点对之间的*短路径 255
7.6 AOV网和拓扑排序 260
7.6.1 AOV网和拓扑排序的概念 260
7.6.2 拓扑排序算法 261
7.7 AOE网和关键路径 265
7.7.1 AOE网和关键路径的概念 265
7.7.2 关键路径的确定 267
7.8 图的简单应用举例 269
本章小结 277
习题7 278
第8章 排序 281
8.1 排序的基本概念 281
8.2 插入排序 284
8.2.1 直接插入排序 284
8.2.2 希尔排序 286
8.3 交换排序 288
8.3.1 冒泡排序 288
8.3.2 快速排序 291
8.4 选择排序 294
8.4.1 直接选择排序 294
8.4.2 堆排序 295
8.5 归并排序 302
8.5.1 两个相邻有序表的一次归并过程 303
8.5.2 一趟归并排序过程 303
8.5.3 二路归并排序 304
8.6 各种内排序方法的比较和选择 305
8.6.1 各种内排序方法的总结 305
8.6.2 各种内排序方法的比较 305
8.6.3 排序方法的选择 306
8.7 排序的简单应用举例 307
本章小结 311
习题8 312
第9章 查找 315
9.1 查找的基本概念 315
9.2 线性表的查找 316
9.2.1 顺序查找 316
9.2.2 二分查找 317
9.2.3 分块查找 320
9.3 树表的查找 323
9.3.1 二叉排序树 323
9.3.2 平衡的二叉排序树 330
9.3.3 B-树 335
9.4 散列表的查找 342
9.4.1 散列表的概念 342
9.4.2 散列函数的构造方法 344
9.4.3 处理冲突的方法 347
9.4.4 散列表的运算 351
9.4.5 散列表的查找及分析 355
9.5 查找的简单应用举例 357
本章小结 362
习题9 363

第10章 文件 365
10.1 文件的基本概念 365
10.2 顺序文件 367
10.3 索引文件 368
10.4 索引顺序文件 370
10.4.1 ISAM文件 370
10.4.2 VSAM文件 373
10.5 散列文件 375
10.6 多关键字文件 376
10.6.1 多重表文件 376
10.6.2 倒排文件 377
本章小结 378
习题10 379
参考文献 380

前沿

再 版 前 言
本书是普通高等教育“十一五”***规划教材。本书较系统地介绍了程序设计中*常用的一些数据结构,如线性表、栈和队列、数组、串、树、图等;阐述各种数据结构的逻辑关系,讨论它们在计算机中的存储表示,以及在这些数据结构上的运算,并对其算法的复杂度进行简要的分析;另外,还介绍了程序设计中常用的各种排序和查找算法;每章中的“简单应用举例”,既是本章算法的综合应用,也可作为本章实训内容和课程设计的综合练习,具有很强的实用性和可操作性。
本书共分10章,内容包括:数据结构的概念,几种基本的线性结构(如线性表),栈和队列,串,几种非线性结构(如多维数组和广义表),树,图,常用的数据处理技术(如排序),查找,文件的存储结构和组织方法等。
本书既重视理论又重视实践,配有大量的习题和例题,解释颇为详细。全书采用C语言作为描述语言,并有详细的注释,书中全部程序均上机在TURBO C 2.0环境下进行验证并调试通过,同时给出部分程序的运行结果。
本书是作者在讲授“数据结构”和“高级程序设计语言”等课程20余年教学经验的基础上,集历年各种版本教材及作者多年来的备课笔记之精华,结合本科教学特点编写而成的。因此,学生通过相关内容的学习之后,可以直接使用书中算法或程序,有助于提高学生对所学知识的融会贯通和灵活应用,培养学生理论联系实际的良好学风。
本书第1版于2006年出版,经过近10年在上海交通大学、上海大学、海南大学、山东理工大学等多所高校的计算机及应用、微电子和信息工程、信息安全、计算机信息管理和自动控制等相关专业的多届学生中的使用,取得了较好的教学效果并获得了较高的评价。另外,本书还于2009年9月获得上海交通大学第12届优秀教材二等奖。
本书在再版过程中,山东理工大学电气与电子工程学院姜吉顺副教授对全书进行了全面修订并对书中的例题和习题以及书中的全部程序进行了验证和调试。
本书的再版不仅更正了原书中的疏漏和错误,也增补了一些细节;另外,在文字的叙述方面也进行了一些润色和删繁就简的工作。
此书的再版,首先要感谢电子工业出版社和冉哲编辑。因为目前的出版业与10年前已发生很大的变化,市场的竞争更加激烈、更为市场化。所以,对于出版社来说,决定一本书是否再版,是需要一定的眼光和需要承担一定风险的。但是,对于一个作者来说,能够在这种情况下,再版一本旧作,比完成一本新书更有成就感。因为,书作为科学的载体,其价值是需要用时间来检验的,只有经得起时间考验的作品,才是真正具有价值的。
原上海大学计算机学院院长张吉锋教授、原上海交通大学软件学院副院长侯文永教授对本书的内容以及实验和课程设计教学环节提出了很多宝贵的意见与建议;上海大学计算机工程与科学学院的曹旻、刘华两位老师,海南大学信息学院信息安全系的周晓谊老师在本书的使用和推介过程中做了大量的工作,并对此书的部分内容提出了一些建设性的修改意见,谨在此一并表示衷心的感谢。
本书主要作为全日制高等学校计算机应用专业、微电子和信息工程专业、计算机信息管理和经济信息管理类等专业普通本科学生的专业基础课教材;也可以作为上述专业高职高专学生的参考教材;还可以作为计算机等级考试的参考书,供广大从事计算机应用工作的管理人员和技术人员学习参考。
由于作者水平有限,书中缺点和错误在所难免,希望广大读者批评指正。

作 者
于上海交通大学

数据结构(第2版) pdf下载声明

本pdf资料下载仅供个人学习和研究使用,不能用于商业用途,请在下载后24小时内删除。如果喜欢,请购买正版

pdf下载地址

版权归出版社和作者所有,下载链接已删除。如果喜欢,请购买正版!

链接地址:数据结构(第2版)