课程名称 数 据 结 构
G40,KCa 英文名称 Data Structures
+`9
]L]J]4 课程编号 不填 总学时 60 学 分 不填
E4[
|=< 预修课程 C语言 开课学期 不填
K+Q81<X~ 大纲撰写人 黄刘生
3 8pw 一、教学目标和基本要求
"o#"u[W, 目的:使学生较全面地掌握各种常用的数据结构,提高其数据抽象和程序设计能力,为学习后续软件课程提供坚实的基础。
K@U"^
`G2 基本要求:使学生能够从逻辑结构、存储结构和数据的运算三个方面去掌握各种数据结构的特性, 对算法的时、空复杂性有一定的分析能力,使之能够针对具体的应用问题, 选择合适的数据结构及设计结构清晰、正确有效的算法解决之。
(f5!36mz 二、课程简介
^M6v;8EU 数据结构是计算机学科一门重要的专业基础课,该课程系统地讨论各种常用的数据结构及其应用,以及查找和排序的各种方法及其综合分析比较,培养学生数据抽象和程序设计的能力,算法时、空复杂性的分析能力。
iN+Dmq5 三、教学重点、难点
"5Oog< 1. 概论:重点是了解数据结构的逻辑结构、存储结构及数据的运算三方面的概念及其相互关系,难点是抽象数据类型和算法复杂度的分析方法。
5p"n g8nR 2. 线性表:重点是熟练掌握顺序表和单链表上实现的各种基本算法及相关的时间性能分析,难点是能够使用所学到的基本知识设计有效算法解决与线性表相关的应用问题。
&}32X-~y 3. 栈和队列:重点是掌握栈和队列在两种存储结构上实现的基本运算,难点是循环队列中对边界条件的处理。
?;>s< 4. 串:重点是掌握串上实现的模式匹配算法,这也是本章的难点。
8Fx~i#F T 5. 树:重点掌握二叉树的遍历算法及其有关应用,难点是使用本章所学到的有关知识设计出有效算法解决与树或二叉树相关的应用问题。
)`F?{Sg 6. 图:重点掌握图在邻接矩阵与邻近表上实现的遍历算法。难点是求图的最小生成树、最短路径、拓扑排序等应用算法及其时间性能分析。
w_@NT} 7. 动态存储管理: 重点是内存空间的分配与回收算法,以及可利用空间表的结构。本章难点是无用单元收集算法的理解与掌握。
##Z:/SU 8. 查找:重点掌握顺序查找、二分查找、二叉查找树上查找以及散列表上查找的基本思想和算法实现。本章难点是二叉查找树的删除算法及B-树上的插入和删除算法。
kLMg|48fdI 9. 文件:本章重点是介绍存储在外存上的数据絇OST
http://www.freekaobo.com/post.php? HTTP/1.0
].]yqD4P Pro和更新操作。
v3[Z]+ ] 'P32G?1C&p #tN)OZA 四、教材名称及主要参考书
%\\l/{`eW 《数据结构C语言版》严蔚敏、吴伟民,清华大学出版社,2000。
rmUTl 《数据结构第2版》黄刘生、唐策善,中国科技大学出版社,2001。
?'CIt5n+\{ "Data Structures with C++" Williaw Ford et al., Prentice Hall Inc., 1996.
8wwqV{O7 "Data Structures & Program Design in C, 2nd Ed." Robert Kruse et al., Prentice Hall Inc., 1997.
af\>+7x93 五、课程章节主要内容及学时分配
h|yv*1/| 7A8jnq7m/ 第一章 概 论(3学时)
gsI"G 第一节 基本概念和术语
Nz#T)MGO` 第二节 学习数据结构的意义
Im{50%Y 第三节 抽象数据类型
E{^*^+c"h 第四节 算法的描述和分析
p&B98c 第二章 线性表(6学时)
vi
4
u ` 第一节 线性表的逻辑结构
5,I'6$J
第二节 线性表的顺序存贮结构
g)!B};AA 第三节 线性表的链式存贮结构
Ah='E$t 第四节 顺序表和链表的比较
W
)1)zOD 第三章 栈和队列(6学时)
ul/= 1]1? 第一节 栈
UAnq|NJO 第二节 队列
bRJYw6oA< 第三节 栈与队列的应用实例
{ r`l 第四章 串(4学时)
-dsB@nPiUw 第一节 串及其运算
I$\dT1m$ 第二节 串的存贮结构
w}G2m)( 第三节 串的模式匹配
gTY\B. 第六章 树(10学时)
@ z#;O2 第一节 树的概念
=2s5>Oz+ 第二节 二叉树
>J[g)$, 第三节 二叉树的遍历
BXO(B'1)] 第四节 线索二叉树
Qpndi$2H! 第五节 树和森林
k[6@\D- 第六节 哈夫曼树及其应用 第七节 树与等价问题、树的计数
v/c8P\ 第六章 图(10学时)
V=VL@= 第一节 图的概念
Z 7t 0=U 第二节 图的存贮结构
RU,f|hB4 第三节 图的遍历
gd]vrW'wj 第四节 图的连通性问题
VjtI1I 第五节 最短路径
%:h)8e-; 第六节 有向无环图及其应用
ZO2u[HSO> 第七章 动态存储管理(5学时)
i5?)E7- 第一节 概述
o*:VG\#Z6 第二节 可利用空间表及分配算法
[z]@<99/ 第三节 边界标识法
K7FuMB 第四节 伙伴系统
hqnJ@N$yY 第五节 无用单元收集
g.kpUs 第八章 查找(8学时)
6TbDno/!
' 第一节 基本概念
+uM1#-+h 第二节 静态查找
9bPQD{Qb 第三节 动态查找
j?jEWreq]~ 第四节 散列查找
QUaz;kNC7 第九章 文件简介(2学时)
%/,PY>:| 第一节 文件基本概念
Un]`Gd]: 第二节 顺序文件与索引文件
|b;}'
* 第三节 ISAM和VSAM文件
q =b.!AZy 第四节 散列文件
n]}+ : 六、系教学委员会意见
K8pfk*NZ_@ G&0&*mp "z69jxXo K)]7e?:Wu ?|%^'(
U} 组长签字: 年 月 日
D=mU!rjr1 七、系主任意见
fNFdZ[qOd {v+i!a'+ @~ N:F~ b5_A*-s$M 6^wg'u]c 系主任签字: 年 月 日