案例教学在计算机类课程体系中的设计与实践.docVIP

案例教学在计算机类课程体系中的设计与实践.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
案例教学在计算机类课程体系中的设计与实践   摘要:转型期的民办高校要始终注重学生能力的培养,贯彻授之以渔的教育理念,逐步实现课堂教学开放互动的教学模式,激发学生共同讨论问题的兴趣,增强其分析和解决问题的能力。本文将结合高校计算机类通识课程中的面向过程语言编程实例,剖析排序算法分析,引领学生掌握解决此类题目的方式方法。   关键词:教学模式;实践;举一反三   中图分类号:G642.4 文献标志码:A 文章编号:1674-9324(2018)24-0274-02   首先,课前教师要精心准备教学实例并指导学生提前阅读。已知数据文件IN.DAT中存有200个四位数,并已调用读函数readDat()把这些数存入数组a中,请学生编制一函数jsVal(),其功能是:如果四位数各位上的数字均是0或2或4或6或8,则统计出满足此条件的个数cnt,并把?@些四位数按从大到小的顺序存入数组b中。最后main()函数调用写函数writeDat()把结果cnt以及数组b中符合条件的四位数输出到OUT.DAT文件中。   通过阅读题目,我们首先可以得出:有200个四位数存储在数组a中,那么,学生该如何引用这批数据呢?C语言规定:数组的下标从0开始记,即a[0]、a[1]、a[2]、……、a[199]。   其次,我们要通过编辑jsVal()函数体中的语句,来实现该函数的功能。“如果四位数各位上的数字均是0或2或4或6或8”,请学生认真思考:如何获取一个四位数(例如:6482)的千位、百位、十位、个位上的数字呢?我们不妨进行下面的一组演算:   6482/1000,所得商即为千位上的数字6。   6482/100%10,所得余数即为百位上的数字4。   6482/10%10,所得余数即为十位上的数字8。   6482%10,所得余数即为个位上的数字2。   通过观察上述的演算过程,我们可以整理出关于获取四位数各位上的数字的算法来,也就是,千位上的数字:四位数/1000,百位上的数字:四位数/100%10,十位上的数字:四位数/10%10,个位上的数字:四位数%10。同样,我们也可以以此类推出获取三位数各位上的数字的算法来,即百位上的数字:三位数/100,十位上的数字:三位数/10%10,个位上的数字:三位数%10。   接下来,请学生对已拆分出各位上的数字“均是0或2或4或6或8”进行仔细分析。我们不难发现,其实具有这类特征的数值都是偶数,但千位上的数字却不能为0。对此,我们通过选择结构来完成上述结论的逻辑分析,即if(千位上的数字%2==0百位上的数字%2==0十位上的数字%2==0个位上的数字%2==0千位上的数字!=0)。可在此题目中,我们要对数组a中200个元素去重复执行该项条件的判定,为此,我们需要借助循环结构来遍历数组a中全部元素,即for(i=0;i200;i++)。   再接下来,“则统计出满足此条件的个数cnt”,值得强调的是,如果不存在满足条件的数据,那么,此时cnt的值就是0。换言之,cnt的初始值应置为0。当条件满足时,cnt的值加1,即cnt++。“并把这些四位数按从大到小的顺序存入数组b中”,请学生仔细思考,究竟有多少个被筛选出来的数组a中元素会存入到数组b中,是200个吗?不,是cnt个。我们要将满足上述if表达式的数组a中的元素,逐一地赋值到数组b中,即b[cnt++]=a[i];实际上,我们也正是要对它们进行从大到小的排序。下面,我们就通过对一组无序数列:78、29、86、54来加以分析,从而整理出能够完成指定排序的算法来。分析过程如下所示:   第一趟操作是从第一个位置上的数值开始,进行两两比较。   在第一趟操作中,我们依次将第一个位置上的数值与其后各个位置上的数值作比较。如果后者较大,则交换二者位置上的数值;否则,对应位置上的数值不变。经过4-1次比较后,我们得出四个数中最大数86。如此进行下去,在第二趟操作中,对应位置上的数值共进行4-2次比较,我们得出三个数中最大数78。   第二趟操作是从第二个位置上的数值开始,进行两两比较。以此类推,第三趟操作是从第三个位置上的数值开始,进行两两比较。值得注意的是,在第三趟操作中,共进行了4-3次两两比较,我们得出两个数中的最大数54。以此类推,如果有cnt个数,则要进行cnt-1趟操作,也就是要用外层循环去控制趟数,即for(i=0;icnt-1;i++)。在第i趟中,则要进行cnt-i次比较,也就是要用内层循环去控制每一趟中的两两比较次数,即for(j=i+1;jcnt;j++)。如果当前元素b[i]小于后序元素b[j]时,我们则需要借助中间变量t来完成两数交换,即if(b[i]b[j]){t=b[i];b[i]=b[j];b[j]

文档评论(0)

小马过河 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档