- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
以计算思维为中心的数据结构教学方法探讨.doc
以计算思维为中心的数据结构教学方法探讨
摘要:如何帮助学生学习和掌握数据结构课程蕴含的计算思维,是从事数据结构教学工作的教育者需要考虑的重要问题。文章提出一种基于问题驱动和图示法的教学方法,即以计算思维为中心的教学方法,以稀疏矩阵的转置问题为例说明该教学方法的理念和特点。
关键词:数据结构;计算思维;教学方法;问题驱动;图示法
0引言
在计算机科学中,数据结构是一种在计算机中组织和存储数据,以便高效利用这些数据的有效方式。数据结构主要研究数据在抽象视图和实现视图中的表示和处理方法,其理论性和抽象性较强,要求能够运用计算思维分析并解决问题,被认为是比较难学的课程。基于问题驱动的教学方法是将求解原问题转换成一系列的子问题,通过求解子问题序列最终求解原问题,子问题序列实际上给出运用计算机求解问题的最终目的和思考问题的计算思维轨迹。图示法可以直观、形象地描述每个子问题的求解思路和过程。为了让学生更好更明确地理解什么是计算思维、数据结构中有哪些计算思维、怎样运用计算思维求解问题,通过在教学过程中不断尝试和探索,我们发现将问题驱动与图形演示两种教学手段结合起来是一种行之有效的教学方法,即以计算思维为中心的教学方法。
1问题描述
随机稀疏矩阵是非零元比零元少很多且非零元的分布不具规律性的一种矩阵,转置矩阵是矩阵行列交换后得到的一种矩阵。通常用二维数组表示矩阵,借助二维数组可以实现计算机求解矩阵的转置矩阵。以求解稀疏矩阵M的转置矩阵T为例,求解过程如图1所示。
实现求解稀疏矩阵M的转置矩阵T这个目标,需要依次解决的子问题有在存储器中如何存储二维数组、如何以低空间成本存储稀疏矩阵、如何从存储结构的角度解读需要求解的问题和如何求解新视图中的问题。
2教学过程
按照求解逻辑,将求解稀疏矩阵的转置矩阵问题细化为一个子问题序列,通过依次求解序列中的子问题最终使原问题得到解决。讲解每个子问题的求解方法时,可以运用图示生动形象地描述抽象复杂的求解过程。具体教学过程如下所述。
1)子问题1:如何在存储器中描述二维数组。
这个子问题隐藏的计算思维是如何在线性空间(存储器)中描述非线性结构。为了更形象地说明该子问题的两种求解方法――“以行为主”顺序存储和“以列为主”顺序存储,我们在讲解的过程中使用图2所示的示意图。
2)子问题2:如何以低空间成本存储稀疏矩阵。
随机稀疏矩阵中的非零元非常少,为了节约空间成本,通常只存储其中的非零元信息,但非零元在矩阵中的分布没有规律性,因此除了需要存储非零元的值外,还需要存储非零元在矩阵中的位置信息;三元组(行,列,值)结构可以满足这样的存储需求。一个稀疏矩阵可以表示为一个三元组集合,但三元组集合只给出了稀疏矩阵所有非零元的分布信息、值的信息和部分零元的分布信息,并不能唯一确定一个稀疏矩阵。为了获得所有零元的分布信息,我们需要知道稀疏矩阵的规模信息,即它是多少行多少列的矩阵。低空间成本存储稀疏矩阵M的存储结构图(以“行序为主”存储三元组)如图3所示。
3)子问题3:如何重新解读所求问题。
稀疏矩阵的转置矩阵还是稀疏矩阵,因此目标矩阵T也将按照上述低空间成本存储方案进行存储,那么用存储结构视图重新解读问题“已知稀疏矩阵M,求它的转置矩阵T”,实质上就是已知图3补全图的问题。
4)子问题4:如何根据图3的信息补全图4。
显然,根据M中m、n和t这3个成员的值可以很容易得到T.m、T.n和T.t的值,即T.m=M.n,T.=M.m,T.t=M.t。因此,我们需要解决的关键问题是如何根据M.data[]得到T.data[]。
解决方法1:以T.data[]为主导进行填充,即依次填充T.data[0]、T.data[1]……T.data[T.t-I],并且保证存储是以T的“行序为主”顺序存储的。具体来说,需要对M.data[]进行M.n次扫描,第j(0≤j≤M.n-1)次扫描的任务是将M.datar 1中第j列的元素依次进行行列转换后插人T.data[]中。具体求解过程如图5所示。
解决方法2:以M.data[]为主导进行填充,即依次根据M.data[0]、M.data[1]……M.data[M.t-11填充T.data[],并且保证存储是以T的“行序为主”顺序存储的。具体来说,只需要对M.data[]进行一次扫描,扫描到第k(0≤k≤M.t-1)个三元组时,需要确定该三元组进行行列转换后的新三元组应该填到T.data[]中的什么位置。为了解决这个问题,在填充之前需要对M.data[]中的三元组进行统计分析,分析出M的每一列有多少个元组。假设得到M的第j(0≤j≤M.n-1)列有Nodesj个非零元,那么,实际上得到T
文档评论(0)