- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《数据结构教程》
自学指导
教材:《数据结构教程》,迟乐军等编,北京航空航天大学出版社
教师:曾晓红
单位:昭通师范高等专科学校计算机科学系
2009年5月
一、绪论
1、课程知识体系:《数据结构》是计算机专业一门重要的专业技术基础课程。数据结构的研究范围主要涉及数据的逻辑结构、存储结构和操作的实现,以及常用的查找和排序技术。其内容是程序设计(特别是非数值计算的程序设计)的基础,也是设计和实现编译程序、操作系统、数据系统及其它系统程序和大型应用程序的重要基础。通过这门课程的学习,使学生在软件开发的过程中能够正确、合理地选择数据的存储结构,有效地设计算法,从而提高软件整体质量。本课程的学习将为后续课程的学习以及软件设计水平的提高打下良好的基础。知识体系如下:
(1)数据的定义:数据的逻辑结构、数据的存储结构、数据的运算、线性结构、树形结构、图结构、文件结构、图(树(二叉树(线性表、顺序方法、链接方法、索引方法(线性、树形)、散列方法。
(2)算法的效率问题:对于给定的一类问题:算法需要多少存储空间和时间?最好算法的最坏情况是什么?平均来说,算法的运行好到何种程度?算法一般化到何种程度?什么情况下,最好的算法是什么?
(3)抽象数据类型:抽象数据类型是定义了一组运算的数学模型。把数据结构的存储与实现细节剥离。在适当的抽象层次上考虑程序的结构和算法。封装和信息隐蔽。
2、课程学习要求:
⑴本课程学习范围及要求:本课程将分别讲述数据结构的基本概念、线性表、栈和队列、串和数组、树形结构、图结构、查找、排序等内容。
⑵应掌握的知识点及层次要求:熟悉数据结构常用术语,掌握基本概念,了解算法时间复杂度和空间复杂度的分析与评价;掌握线性表的概念和类型定义、线性表的顺序存储结构和链式存储结构;掌握栈和队列的应用方法,理解栈的重要作用、利用栈实现行编辑,利用栈实现表达式求值;了解数据结构的基本概念,理解常用术语、掌握串的基本概念及其基本运算、掌握串的存储结构;掌握数组和广义表的定义、运算及存储结构、矩阵的压缩存储;掌握树和二叉树的类型定义、运算及存储结构、树的各种表示、各种存储方式和运算,二叉树的概念及其运算和应用、二叉树的非递归运算及应用;掌握图的基本概念、图的存储结构和图的常用算法;掌握排序的概念、熟悉各种排序方法、掌握插入法排序的各种具体实现方法及算法分析、掌握选择法排序的各种具体方法的实现及时间性能分析、掌握交换法排序的具体实现及性能分析、掌握归并排序和基数排序的各自实现算法;掌握各种不同的查找表的查找算法和性能分析(线性表的查找、树表的查找和哈希表的查找以及各种查找的性能分析);掌握文件的概念、顺序文件、索引文件、ISAM文件、VSAM文件、散列文件的组织形式与检索方法。
⑶学员自主学习要求:自学时仔细阅读教材中的例题,从中体会并最终掌握数据结构中的基本概念;认真上机实习,加强对相关知识点的理解;独立完成每个章节后面的练习题;能够用计算机解决一个实际问题,将实际问题的数据信息存入计算机,并设计能解决问题的算法。
⑷面授辅导设计:①串讲本课程;②深入讲解学员在自学过程中普遍遇到的问题;③针对每个学员的个别问题逐一解答。
⑸课程考核要求及考核方式:课程考核方式采用笔试,平时作业成绩占学期成绩的50%。严禁抄袭别人作业,否则,一经发现学期成绩不予及格。
3、学习支持服务方式及承诺:学生可以通过电子邮件(ZTZXH@126.COM)与我进行交流。对于学生在学习中提出的问题,我一定尽快帮助解决,最迟不超过1周帮助学生解决提出的问题。
二、分论
第一章 绪论
1、本章的知识结构:数据结构的基本概念。
2、本章的重点、难点、测评点:数据结构包含数据元素集合和数据元素之间关系的集合。理解算法与数据结构之间的关系。理解算法设计的要求。掌握算法效率度量方法。
3、本章自测题:P17(1~5)。
第二章 线性表
1、本章的知识结构:线性表的特点,线性表的顺序实现和链式实现,线性表的应用;字符串的基本运算,及其应用。
2、本章的重点、难点、测评点:1) 理解线性表的结构和特点,掌握线性表上基本操作的实现算法。2) 掌握顺序存储线性表的表元素与存储单元的对应关系,基本操作的实现算法。3) 掌握链接存储线性表的表元素与存储单元的对应关系。单链表、双向链表和循环链表的存储结构和特点,基本操作的实现算法。4) 理解字符串的存储结构,字符串的基本运算。5) 掌握字符串简单匹配算法;理解字符串KMP匹配算法。6) 具有用用线性表、字符串解决实际问题的能力。
3、本章自测题:P36(1~15)。
第三章 栈和队列
1、本章的知识结构:栈和队列的基本运算及其应用。
2、本章的重点、难点、测评点:1) 理解栈的定义和结构特点,掌握其存储方式(顺序存储与链接存储)和基本操作的实
文档评论(0)