程序开发类课程群框架下“数据结构与算法分析”课程教学实践研究

来源 :考试周刊 | 被引量 : 0次 | 上传用户:kuaijizhidu2009
下载到本地 , 更方便阅读
声明 : 本文档内容版权归属内容提供方 , 如果您对本文有版权争议 , 可与客服联系进行内容授权或下架
论文部分内容阅读
  摘 要: “数据结构与算法分析”在程序开发类课程群中有至关重要的作用。本文以课程群为背景,从教学、实践等方面进行研究,提出课程群框架下的自主学习、合作学习相结合的课堂教学模式、项目驱动的分层实践教学模式及分段管控的多元化实践考核等改革措施,其研究对激发学生长久的学习动力和兴趣有积极的作用。
  关键词: “数据结构与算法分析” 课程群 分层实践 分段管控
  课程群是对教学计划中有相互影响、互动、有序、相互间可构成完整的教学内容体系的相关几门课程组成一个课程间相互连接、相互配合、相互照应的课程群体[1]。2014年提出建设程序开发类课程群,包括C语言程序设计、C 程序设计、数据结构与算法分析、JAVA程序设计、web程序设计、组件开发技术、软件设计模式七门课程。其中“数据结构与算法分析”课程在整个课程群具有承上启下、举足轻重的地位,决定程序开发类课程群的成效。
  一、“数据结构与算法分析”课程的现状
  1.课程理论性强,难度大。
  调研发现:非计算机专业近80%的学生都感觉课程难,即使计算机专业的有近50%的学生,感觉该课程难学,这种畏惧思想影响学习兴趣。
  2.先导课程掌握不扎实,课程推进困难。
  教学计划中C 程序设计、实践和该课程分别安排在第2和第3个学期。暑假将两门课割裂了,造成是否介绍先导课的困境。
  3.学生动手水平参差不齐,单一的实践安排难以满足不同的需求。
  目前,课程的实践安排对所有的学生相同,对于动手强的学生可能在寝室就完成题目,而对编程能力不强的学生可能根本不知该如何下手,久而久之学生就失去开发热情。
  4.课程管控不足,课程考核不能反映学生的真实水平。
  目前课程的评定以卷面成绩为主,实践证明有些学生根本不会写代码但他却能拿到很高的分数。
  二、教学改革措施
  1.课程群中相关课程开课时间的精细化安排。
  (1)开课时间安排。
  C 程序设计包括64上课课时和16实践课时,将C 课程实践调整到第3学期第1周上,而数据结构与算法分析课程从第2周以后开始上,这样就将两门课紧密地衔接起来。这种一门课程一分为二的方法促进了C 课程,同时也保证“数据结构与算法分析”课程的顺利进行。
  (2)教学内容及学时分配。
  为呼应课程群中的后续课程,该课程内容是贯穿程序设计、软件设计模式的思想和观点。该课程采用面向对象和抽象数据类型观点介绍数据结构,集中体现分解、抽象和信息隐蔽的基本原则,抽象数据类型是中枢,展示信息结构转换的三个重要阶段:数学模型、抽象数据类型、数据结构与算法。其理论教学环节的安排为:数据结构的基本概念(2),表、栈和队列(6),树(8),散列(4),优先队列(7),排序(12),不相交集(4),图论算法(7),算法设计技巧(4),摊还分析(4),高级数据结构(6);课内实践的安排:栈和队列(2),表达式树(2),散列、优先队列(2),排序(2),不相交集(2),深度优先搜索应用(2),贪心、分治算法(2),AA树、treap数(2)。
  2.课堂教学模式改革
  (1)注重启发式教学,建立自主学习、合作学习相结合的教学模式。
  为强调思维训练,采用讲、做穿插的授课方式,教师采用示例案例授课时学生采用自主学习模式,是教-做-答疑的互动、有反馈方式。它强调教中实践、实践中思考、交流中提升;自主学习完后各小组通过“以强带弱、以老带新”的方式合作完成综合实践作业。
  具体讲解时,(1)首先引入案例,然后给出C 实现的方法,最后详细展开相应数据结构及操作实现;(2)一题多解、一题多语,如对同一问题采用不同的数据结构实现方法,对比讲解,多语言实现为拓展作业;(3)难点分散,如将栈与非递归处理技术分别在栈、二叉树非递归算法、快速排序与归并排序的非递归算法等多处讲解;(4)图示讲解和动画展示相结合。
  (2)标准化教学与微课程教学模式相结合。
  为了确保课程的可持续发展,课程采用项目组集体备课、集体讨论、分头准备的方式。课程组骨干教师经过多次讨论后修订了课程教学大纲,形成了标准教案、PPT及算法演示视频。为充分利用学生的课余时间,采用课程微课程化,微课视频一般10分钟左右[2],选择与生活比较贴近的数据结构(比如栈、队列等)和基础实践内容微课化。
  3.项目驱动的分层实践教学模式研究。
  教育心理学家发现:学习是累积性的,较复杂、较高级的学习是建立在基础性的学习基础之上的[3]。因此,课程的实践教学以贯穿课程群的项目进行驱动,提出“注重基础、综合应用、提高创新”的三层次实验教学模式,以基础、设计、综合三个方面的实践能力培养为中心,全方位地培养学生的动手能力和创新能力。
  基础类实践通常是对教材上所涉及的数据结构及相关操作进行上机验证,要求学生掌握相关数据结构,提高学生的软件设计规范化能力。这类实践通常在介绍完相关知识后以课程作业的方式发放,要求学生在规定时间内完成,教师以晚自习的形式进行个别指导;设计类实践要求学生对给定的题目进行数据结构的设计及算法实现,题目是从贯穿课程群中的项目案例中切割出来的。实践中我们鼓励学生一题多解,并分析不同解的时、空代价。这类实验通常是课程内实验题目,要求每个学生独自完成,教师全程指导、重点考核;综合类实践是对C 实践课程中学生已完成题目的重新设计,以小组为完成单位,人员分组原则上是C 实践的人员分组。该类实践培养学生分析、设计实际项目的能力和创新能力。教师对有强烈要求的学生通过答疑的方式进行指导。各小组完成后需要进行结题答辩,答辩中教师会对完成情况进行评价,从而引出后续课程。
  4.课程考核与过程控制。
  我们采用分段控制的多元化实践考核方式:期末机考30% 基础实践20%(程序代码 报告 随机面试) 设计实践40%(课前准备材料 完成代码 报告) 综合实践10%(报告 答辩)。考核方式强调对课程的过程监控,基础实践的每一次完成情况能够给教师提供重点监控的学生名单,通过晚自习的重点指导确保学生弄懂相关知识点、顺利进行实践课任务,为保证设计实践课的完成质量,要求学生在课前精心准备并提交准备材料。综合实践强调以强带弱,最后通过总结引出下一门课程,从而保持学生长久的学习动力。
  三、结语
  数据结构与算法设计是程序开发类课程群中最重要的一门课程,其成败直接决定整个课程群的成败。在不影响其他课程下的课程群开课时间微调保证课程的顺利进行;创新的教学课堂模式激发学生自主式、探索式学习;项目驱动的实践模式将课程群中的课程更紧密地结合起来;分层的实践教学满足不同层次学生的需求;教学过程的管控进一步确保教学的顺利推进。该课程改革对课程群中其他课程改革有积极的作用。
  参考文献:
  [1]马赛,李方能,吴正国,卜乐平.《信号与系统》课程群的建设与教学改革探索[J].高等教育研究学报,2010.3.
  [2]梁乐明,曹俏俏,张宝辉.微课程设计模式研究—基于国内外微课程的对比分析[J].开放教育研究,2013,19(1).
  [3]哈斯.《数据结构》课程中使用逐步演示法进行算法教学的实验研究[D].呼和浩特:内蒙古师范大学,2007.
  [4]李净,多琦,袁小华.信息管理与信息系统专业“软件工程”课程教学研究[J].计算机教育,2007,19.
  项目:上海海洋大学《数据结构与算法分析》重点课程建设
其他文献
摘 要: 阅读理解中对有关信息的提取是至关重要的,推测和联想在阅读理解过程中有着重要的意义。本文介绍了中级水平学生或读者对阅读中词义、句义、段义等文章内部含义的猜测情况,特别指出了猜测词义是一个包含多种因素在内的复杂过程。通过对阅读材料中词的内部构造、一字多义、细节、逻辑、语境等因素的推测和联想,有助于在阅读中排除生词的障碍,顺利理解文章的思想内容,提高理解篇章的能力,提升阅读水平。  关键词:
篮板球是球队获得控制球权的重要来源之一,是篮球比赛攻守转化的关键。正确的判断是争夺篮板球的首要因素,抢位挡人技术是拼抢篮板球的关键。  1.研究方法  通过查阅资料和临场观察,结合在日常教学、训练、比赛中的心得体会,我对争夺篮板球的能力做了初步探讨。  2.讨论和分析  2.1正确判断篮板球的落点是拼抢篮板球的首要因素  判断篮板球的落点是指在篮球比赛中,运动员根据投篮者出手动作和球的飞行路线,对
摘 要: 本文通过swot分析法,对中学体育在学校发展的优势(Strengths)、劣势(Weakness)、机遇(Opportunities)和威胁(Threats)等因素进行了综合分析,探索了中学体育在学校的发展过程中停滞不前的原因,旨在为促进中学体育在学校的可持续发展提供参考和借鉴。  关键词: 中学体育 swot分析 学校发展  1.中学体育在学校的地位  体育是学校教育和体育发展的重要基
唐宋八大家之一欧阳修曾有诗曰:“文章看落笔,议论驰后先,破石出至宝,决高泻千川。”意思是说写文章要特别注重开篇落笔,如果下笔便石破天惊、涌现精华,则全篇就如高崖泻水,
摘 要: 体育政策在我国竞技体育发展的各个时期,都有不可替代的导向和保障的作用,而且在我国当代竞技网球运动项目的发展中发挥着重要而独特的作用。本文通过文献资料法、逻辑分析法,运用社会学和政策科学的相关理论,以功能维度将竞技网球运动领域内的政策划分为三类:竞赛政策、训练政策、管理政策,形成三位一体的政策体系,并从政策的正功能和负功能两方面进行论述,以期从不同角度全面地观察政策功能的实践效果,并总结数
摘 要: 本文介绍了任务引导式教学方法及该方法在程序设计类课程中的具体实践过程,该方法的实施提高了课堂教学质量,为实践环节的改革提供了参考。同时,实践证明,该方法充分调动了学生学习的主动性,增强了学生的实践动手能力和团队协作意识。  关键词: 任务引导式教学 程序设计类课程 教学方法  程序设计类课程是高校计算机专业开设的一类主要的专业课程,通常至少开设一门,此类课程多为实践性内容较多。程序设计类
摘 要: 运筹学是一门应用性很强的学科,本文针对高校教师如何选择运筹学实验教学软件进行讨论,旨在提高高校运筹学教学质量,强化教学效果。  关键词: 运筹学 实验教学 教学软件  1.运筹学概述  运筹学是一门依照给定条件和目标从众多方案中选择最佳决策方案的应用科学,自其诞生以来,已在军事、工农业、经济和社会问题等多个领域得到广泛的重视和应用。现在,它已与我们的日常生活息息相关。运筹学已经成为安排工
《算法与程序设计》是高中信息技术选修课程,但是《算法与程序设计》教学一直存在“难教”和“难学”的问题,因为程序设计本身抽象、枯燥,逻辑思维性强。对于一个初学者而言已经比较困难,而且要对所求解的问题进行算法分析;另外,传统教学方式不但不利于学生学习兴趣和思维能力的培养,反而会使学生程序设计思路狭窄,设计程序解决实际问题的能力与变通能力较弱。通过多年来的教学实践,笔者认为:注重学习兴趣培养,重视算法分
摘 要: 《数控加工技术》是数控技术应用专业的一门重要专业主干课,涉及理论内容较多,实践性较强。本文结合职业学校《数控加工技术》课程教学现状和教学特点,总结教学的实践经验,积极探索适合本课程教学的多元化教学手段、方式与方法应用于课程教学实践,以强化本课程的教学效果。  关键词: 《数控加工技术》 教学方法 教学效果  《数控加工技术》课程是职业学校数控技术专业的一门重要的专业主干课,通过本课程的学