ImageVerifierCode 换一换
格式:DOCX , 页数:19 ,大小:22.29KB ,
资源ID:23092654      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/23092654.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(《数据结构》课程大纲模板.docx)为本站会员(b****2)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

《数据结构》课程大纲模板.docx

1、数据结构课程大纲模板数据结构课程教学大纲本课程教学大纲依据网工专业2015级人才培养方案制定。一、课程说明课程名称:数据结构 课程编号:1261D03总学时:80学时 总学分:5.5学分学时分配:理论56学时,上机24学时课程性质:专业必修课 先修课程:C语言程序设计 适用专业:网工开课学期:第二学期二、教学目标与要求教学目标:通过本课程教学,使学生了解计算机科学各领域的数据结构知识,及有关的应用软件所要用到的各种数据结构知识,理解常用的数据结构及内在的逻辑关系,掌握计算机软件设计中的算法知识,熟悉软件设计和编程技能,旨在培养初步对不同的存储结构和相应算法的对比,有一定的算法改进能力,并为学生

2、日后从事软件开发和程序员奠定基础。同时,作为编译程序、操作系统、数据库系统课程学习的理论基础,也为学生后续课程的顺利学习提供条件。教学要求: 通过本课程的学习,在基础方面,要求学生能够掌握常用数据结构的基本概念及其不同的实现方法;在技能方面,通过系统学习能够在不同存储结构上实现不同的运算,并对算法设计的方式和技巧有所体会。总言之,使应用者较全面的掌握各种常用的数据结构,提高运用数据结构解决实际问题的能力。学习本课程必须具备高级语言程序设计(如C语言)的基础知识与基本技能。它的后续课程为操作系统、数据库原理等。数据结构中存储结构及基本运算的实现需要程序设计的基本知识和编程的经验及能力,本课程的大

3、部分实例均是用C语言实现的,故要求较熟练地掌握C语言。通过本课程的学习,使学生深透地理解数据结构的逻辑结构和物理结构的基本概念以及有关算法,培养基本的、良好的程序设计技能,编制高效可靠的程序,为学习操作系统、编译原理和数据库等课程奠定基础。教学重点:1.掌握数据结构的概念及术语。 2.掌握线性表(栈、队列)的存储结构(顺序和链式存储)、算法描述及应用。 3.掌握数组的顺序存储和特殊矩阵的压缩存储。 4.掌握树的基本概念和术语,掌握二叉树的基本性质和特点、存储结构及算法描述、二叉树的遍历、树、森林与二叉树的转换。掌握最优二叉树(哈夫曼树)的特点及应用。 5.掌握图的基本概念和术语、存储结构(邻接

4、矩阵、邻接表、十字链表、邻接多重表)、图的遍历、图的连通性(最小生成树)。 6.掌握查找的基本概念、基于线性表的查找方法(顺序、折半)。7.掌握插入类排序(直接、折半、表、希尔等插入排序)、交换类排序(冒泡、快速排序)。教学难点: 1.掌握算法时间复杂度。 2.掌握线性表的顺序和链式存储存储结构、算法描述及应用。 3.掌握数组的顺序存储和特殊矩阵的压缩存储。 4.掌握二叉树的基本性质和特点、存储结构及算法描述、二叉树的遍历、树、森林与二叉树的转换。掌握最优二叉树(哈夫曼树)的特点及应用。 5.掌握图的邻接矩阵、邻接表、十字链表、邻接多重表的存储结构、图的遍历、图的连通性(最小生成树)。 7.掌

5、握哈希表的构造、查找方法(顺序、折半、快速)。3、教学内容与目的 (一) 绪论1、什么是数据结构 2、基本概念和术语 3、抽象数据类型的表示与实现 4、算法和算法分析 教学目的:介绍数据结构课程的研究对象,基本术语,掌握算法的要领,描述算法的类语言。了解数据结构的发展概况及其在计算机中的地位。教学重点:1、熟悉各名词、术语的含义,特别是数据的逻辑结构和存储结构之间的关系。分清哪些是逻辑结构的性质,哪些是存储结构的性质;2、了解抽象数据类型的定义、表示和实现方法;3、理解算法五个要素的确切含义:?动态有穷性(能执行结束);?确定性(对于相同的输入执行相同的路径);?有输入;?有输出;?可行性(用

6、以描述算法的操作都是足够基本的);4、掌握计算语句频度和估算算法时间复杂度的方法。教学难点:1、掌握数据结构的意义及数据结构的基本内容;2、掌握数据结构及数据、数据元素等相关概念;3、掌握算法描述的方法;4、算法时间复杂度的计算。教学方法与手段:讲授式、讨论式、案例教学作业形式:作业,辅导答疑(二) 线性表1、线性表的类型定义 2、线性表的顺序表示和实现 3、线性表的链式表示和实现 4、一元多项式的表示及相加 教学目的:掌握线性表的逻辑结构、顺序存储结构和链式存储结构。掌握在线性表上实现基本运算的算法。 教学重点:1、线性表的定义及逻辑上的特点;2、顺序表上插入、删除和定位运算的实现;3、单链

7、表的结构特点及类型说明;4、头指针和头结点的作用及区别;指针操作;5、定位、删除、插入运算在单链表上的实现;6、循环链表、双链表的结构特点;及其删除与插入运算的实现。教学难点:1、线性表与线性结构的联系与区别;2、线性表的顺序存储结构及其运算; 3、头结点在链表中的作用和指针的操作;4、单链表存储结构定义,删除、插入运算中的指针操作顺序;5、单链表的基本运算的实现;6、循环链表、双链表上指针的操作顺序及其相关运算。教学方法与手段:讲授式、讨论式、案例教学作业形式:作业,辅导答疑(三) 栈和队列1、栈的类型定义2、栈的应用举例3、栈与递归的实现4、队列的类型定义教学目的:掌握栈和队列的逻辑结构定

8、义,掌握在两种存储结构上如何实现栈和队列的基本运算,掌握栈在程序设计中的应用。 教学重点:1、栈的定义及逻辑特点;栈上的基本运算;2、栈的顺序存储结构及运算实现;链式存储结构;3、入栈、出栈等运算在链栈上的实现;4、队列的定义及逻辑特点;队列上的基本运算;5、队列的顺序存储结构及其上的运算实现;6、队列的链式存储结构;7、入队、出队等运算在链队列上的实现。教学难点:1、顺序栈基本运算的实现;2、顺序栈的溢出判断条件; 3、栈的应用;4、循环队列的队空、队满判断条件;循环队列上的插入、删除操作。教学方法与手段:讲授式、讨论式、案例教学作业形式:作业,辅导答疑(四) 串1、串类型的定义2、串的表示

9、和实现3、串的模式匹配算法4、串操作应用举例教学目的:掌握字符串的存储结构,以及字符串的操作算法。教学重点:1、熟悉串的定义及串的基本操作;2、串的两种存储方式;3、字符串的运算;4、串的模式匹配算法。教学难点:1、串的基本运算的综合应用;2、串的模式匹配算法。教学方法与手段:讲授式、讨论式、案例教学作业形式:作业,辅导答疑(五)数组和广义表1、数组的定义2、数组的顺序表示和实现3、矩阵的压缩存储4、广义表的定义和存储结构5、广义表的递归算法教学目的:掌握数组的顺序存储和特殊矩阵的压缩存储。了解广义表的应用。 教学重点:1、多维组的逻辑结构,两种顺序存储方式;2、计算给定元素在存储区中的地址;

10、3、对称矩阵、三角矩阵的压缩存储方式;4、计算给定元素在存储区中的地址;5、稀疏矩阵的三元组表表示方法;6、了解广义表的定义、表示及存储。教学难点:1、了解数组的两种存储表示方法,并掌握数组在以行为主的存储结构中的地址计算方法;2、稀疏矩阵的压缩存储表示下的运算的实现;3、了解稀疏矩阵的三类压缩存储方法的特点和适用范围,领会以三元组表示稀疏矩阵时进行矩阵运算采用的处理方法;4、了解广义表的结构特点及其存储表示方法。教学方法与手段:讲授式、讨论式、案例教学作业形式:作业,辅导答疑(六) 树和二叉树1、树的定义和基本术语2、二叉树3、遍历二叉树和线索二叉树4、树和森林5、回溯法与树的遍历6、赫夫曼

11、树及其应用教学目的:掌握树的基本概念和术语,掌握二叉树的基本性质和特点、存储结构及算法描述、二叉树的遍历、树、森林与二叉树的转换。掌握最优二叉树(哈夫曼树)的特点及应用。教学重点:1、二叉树的定义、性质、逻辑特点及五种基本形态、基本运算; 2、二叉树的链式存储结构、顺序存储结构及其类型说明; 3、二叉树链式存储结构的组织方式; 4、二叉树的三种遍历方法及其算法,以遍历为基础在二叉树上实现的几种运算; 5、哈夫曼树和哈夫曼算法;森林与二叉树的转换。教学难点:1、二叉树的递归定义;2、二叉树链式存储结构的组织方式;3、三种遍历的主要区别;二叉树上的复杂运算4、森林与二叉树的转换;5、哈夫曼算法及其

12、应用。教学方法与手段:讲授式、讨论式、案例教学作业形式:作业,辅导答疑(七) 图1、图的定义和术语2、图的存储结构3、图的遍历4、图的连通性问题5、有向无环图及其应用6、最短路径教学目的:掌握图的基本概念和术语、存储结构(邻接矩阵、邻接表、十字链表、邻接多重表)、图的遍历、图的连通性(最小生成树)。理解拓扑排序及关键路径和最短路径的应用及意义。教学重点:1、理解图的定义、术语及其含义,各种图的邻接矩阵表示法及其类型说明;2、理解并掌握图的按深度优先搜索遍历方法和按广度优先搜索遍历方法;3、领会生成树和最小生成树的概念;4、掌握由Prim算法思想构造最小生成树按Prim算法思想;5、掌握拓扑序列

13、和拓扑排序的概念,拓扑排序、关键路径、最短路径的算法思想。教学难点:1、正确理解与区别图的常用术语;2、区别图的两种存储结构的不同点及其应用场合;3、关键路径的算法思想;最短路径的算法思想。教学方法与手段:讲授式、讨论式、案例教学作业形式:作业,辅导答疑(八) 查找1、静态查找表2、动态查找表3、哈希表教学目的:掌握查找的基本概念、基于线性表的查找方法(顺序、折半)。理解基于树的查找方法(二叉排序树、平衡二排序叉树)。教学重点:1、查找表的基本概念及查找原理;顺序存储结构、顺序表及其类型说明;2、查找运算在查找表和有序表上的实现;3、二叉排序树的定义、性质及各结点间的键值关系,查找算法和基本思

14、想;4、平衡二叉排序树的概念;B-树和B+树的概念;5、散列表及散列存储和散列查找的基本思想;各种散列表的组织、解决冲突的方法;教学难点:1、理解查找表的逻辑结构是集合,它的运算以查找为核心;2、二叉排序树上的插入算法;平衡二叉树的旋转平衡算法;3、散列表上的有关算法。教学方法与手段:讲授式、讨论式、案例教学作业形式:作业,辅导答疑(九) 内部排序1、插入排序2、快速排序3、选择排序4、归并排序5、基数排序6、各种内部排序方法的比较讨论教学目的:掌握插入类排序(直接、折半、表、希尔等插入排序)、交换类排序(冒泡、快速排序)。理解选择类排序、归并类排序和基数类排序。 教学重点:1、排序基本概念及

15、内排序和外排序、稳定排序和非稳定排序的区别;2、插入排序、冒泡排序、快速排序、直接选择排序、堆排序的基本思想、基本步骤和算法;3、归并排序的思想;两个有序文件合并的方法和算法;4、二路归并排序的算法和时空性能;教学难点:1、快速排序算法;2、堆排序方法。教学方法与手段:讲授式、讨论式、案例教学作业形式:作业,辅导答疑章节学时分配表章节学时分配理论实践(一)绪论1、什么是数据结构 2、基本概念和术语 3、抽象数据类型的表示与实现 4、算法和算法分析 22(二)线性表1、线性表的类型定义 2、线性表的顺序表示和实现 3、线性表的链式表示和实现 4、一元多项式的表示及相加 86(三)栈和队列1、栈的

16、类型定义2、栈的应用举例3、栈与递归的实现4、队列64(四)串1、串类型的定义2、串的表示和实现3、串的模式匹配算法4、串操作应用举例2(五)数组和广义表1、数组的定义2、数组的顺序表示和实现3、矩阵的压缩存储4、广义表的定义和存储结构5、广义表的递归算法4(六)树和二叉树1、树的定义和基本术语2、二叉树3、遍历二叉树和线索二叉树4、树和森林5、回溯法与树的遍历6、赫夫曼树及其应用104(七)图1、图的定义和术语2、图的存储结构3、图的遍历4、图的连通性问题5、有向无环图及其应用6、最短路径104(八)查找1、静态查找表2、动态查找表3、哈希表62(九)内部排序1、插入排序2、快速排序3、选择

17、排序4、归并排序5、基数排序6、各种内部排序方法的比较讨论82合计80四、教学方法与手段1、理论部分以讲授法为主,结合讨论及课堂练习实现教学目的。2、传统教学手段与多媒体等现化手段相结合。3、重视实验教学,要求学生利用一切可利用的时间和机会去实验室,实现并验证书本上的各种算法,达到真正实现教学目的。五、考核与成绩评定方式本课程为考试科目,课程结束后采用闭卷考试。考核总成绩中,平时成绩占30%(出勤占20%,学习态度占10%),期末考试占70%;考核范围为本大纲规定的基本要求教学内容。六、教材与主要参考书目(一)教材严蔚敏、吴伟民,数据结构(C语言版)(ISBN:9787302023685),清

18、华大学出版社,2009.4 (二)主要参考书目严蔚敏、李冬梅、吴伟民,数据结构(C语言版)(ISBN:9787115234902),人民邮电出版社,2011.2 苏仕华、魏韦巍、王敬生、刘燕君,数据结构课程设计(ISBN:9787111295495),机械工业出版社,2010.3七、实践教学环节大纲(一)上机实验(1261ZA3)上机学时:24学时 上机项目数:9上机学分:1学分上机操作项目内容、能力标准和学时分配:章节项目名称上机类型主要内容应达到的基本要求或能力标准课时实验一一元二次方程求解验证复习函数定义,函数调用和参数传递及相关知识。熟练掌握2实验二顺序表的操作验证、操作建立顺序表,并

19、完成查找、插入、删除操作。熟练掌握2实验三单链表的操作验证、操作实现一个简单的学生表或图书表,能够进行简单的录入、查询、修改、删除。熟练掌握4实验四栈的应用验证、操作利用栈完成括号匹配熟练掌握2实验五队列的应用验证、操作利用队列模拟病人看病熟练掌握2实验六二叉树的遍历及应用验证、操作利用二叉链表方法建立二叉树,实现二叉树的前、中、后序三种遍历算法。并运用遍历算法实现二叉树的其他操作,如计算二叉树结点个数、叶子结点个数、二叉树的高度等。熟练掌握4实验七图的遍历验证、操作利用邻接矩阵、邻接表建立图并实现深度优先遍历和广度优先遍历算法。熟练掌握4实验八查找算法设计与实现验证、操作选择两种查找算法实现

20、查找并比较。熟练掌握2实验九排序算法设计与实现验证、操作选择两种排序算法实现排序并比较。熟练掌握2 (二)课程设计(1261ZB1)1课程设计学时:1周(不占课内学时)2课程设计学分:1学分3课程设计选题要求:选题要符合本课程的教学要求,通常应包含如下大部分知识点的综合设计:(1) 顺序表的建立、查找、删除、修改等基本操作; (2) 单链表的建立、查找、删除、修改等基本操作;(3) 栈的建立、查找、删除、修改等基本操作;(4) 二叉树的建立、遍历等操作;(5) 哈夫曼树与哈夫曼码;(6) 图的遍历;(7) 最小生成树;(8) 哈希查找;(9) 各种排序算法的比较注意选题内容得先进性、综合性、实

21、践性,应适合实践教学和启发创新,应结合工程实际情况进行选题,并且有一定的实用价值。4课程设计基本任务:(1) 根据实现的功能,分析出合理的解决问题的方法;(2) 能编写简练、功能齐全的程序,并能正确运行;(3) 学会写规范的说明书、算法描述、流程图;(4) 撰写格式规范、内容详实的课程设计报告,提交程序文件;(5) 提高综合运用所学知识独立分析和解决问题的能力。5课程设计流程(1) 选定设计课题,下达设计任务选题可由指导教师选定,或由指导教师提供若干选题供学生选择,也可由学生自己选题,但学生选题必须通过指导教师的批准。指导教师在公布课程设计课题时一般应包括以下内容:课题名称、设计任务、技术指标

22、和要求、参考文献等内容。(2) 教师讲解介绍课程设计的内容以及课程设计的要求、安排、考核方法、注意事项等。讲授必要的课题背景和相关知识、原理,帮助学生明确任务,组织学生分组并讨论课程设计的任务。(3) 学生查询资料,并设计学生设计内容包括:课题名称及要求、设计方案(给出功能模块设计、流程图等内容)、同组同学的分工任务等。(4) 教师审查审查功能模块设计是否正确,流程图等是否合理。(5) 学生编程与调试通过教师审查后,学生开始做详细设计包括:程序中所采用的数据结构及存储结构的说明、算法的设计思想、以及具体功能实现即开始编程。对编写好的程序进行调试和测试,并积极解决遇到的问题。(6) 提倡团队合作

23、精神课程设计任务由同组同学分工合作完成,所以大家要求步调一致、协作完成。(7) 实践性环节考核对本组设计编写的程序文件进行考核,教师对其综合应用能力和实验能力进行简单的答辩与功能检查,然后再综合实验结果给出实际操作评定成绩。(8) 撰写课程设计报告课程设计报告应认真书写,内容要规范、正确(课程设计报告格式和内容参见附录)。6课程设计进程安排序号内容时间(天)1教师讲解0.52选定课题,学生分组,了解并讨论设计任务0.53学生查询资料并设计方案14学生编程25调试与测试16实践性环节考试17撰写课程设计报告1合计6-77课程设计考核方法及成绩评定(1) 数据结构课程设计报告的综合成绩 约占40%(2) 实际动手能力 约占40%(3) 创新能力 约占10%(4) 态度和纪律 约占10%成绩按照优秀、良好、中等、及格和不及格五档。8课程设计主要参考书:苏仕华、魏韦巍、王敬生、刘燕君. 数据结构课程设计M北京:机械工业出版社,2010. 执笔人:刘波教研室审核签名:院系审核签名:信息工程学院网工教研室编制日期:2016年1月

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1