标题 | 算法的概念教学设计案例 |
范文 | 算法的概念教学设计案例 目标: 1、知识目标:了解算法。分析算法。 2、能力目标:体验程序的独特魅力,了解编程加工的内在机制,培养学生的创新能力。 3、情感目标:通过编程实现信息的加工,激发学生的兴趣,增加学生的成就感。 重点:如何分析算法,算法的概念 ,算法的表示 难点: 如何写算法。理解用算法描述实际问题,理解人的思维在计算机工作中发挥的作用。 方法:讲授法,演示法,归纳法 教学反思: 教 学 过 程 一、导入 在学习程序设计时,既要掌握所使用的某种计算机计算机语言如PASCAL语言,更好掌握解题的方法和步骤,这是程序设计中的关键。语言只是一个工具,只懂得语言的规则并不能编制出有效的高质量的程序,下面所讲座的算法,就是研究解题的步骤和方法,这是编程的基础,同时也是我们解数理化题的基础。 著名计算机科学家沃思提出一个公式: 数据结构 + 算法 = 程序 二、新授 什么是算法:广义地说,为解决一个问题而采取的方法和步骤,就称为“算法”。或者说:算法是解题方法的精确描述。解决一个问题的过程,就是实现一个算法的过程。 1.做任何事情都有一定的步骤。例如要计算的值,无论手算,心算,或用算盘,计算器计算,都要经过有限的事先设计好的步骤。 2、对同一个问题,往往有不同的解题方法和步骤 如 方法1:顺序计算1-1/2+1/3-1/4+1/5……+1/99-1/100,一直加到100 加99次 方法2:先计算+,再计算减,即1+1/3+1/5……+1/99,1/2+1/4+1/6……+1/100当然各种方法有优劣之分。 3、不仅数值计算的问题要研究算法,实际上,做任何事情。都需要事先设想好的步骤和方法,这就是算法。 计算机算法可分为两大类别: 数值运算 非数值运算 数值运算举例:求数值解,例如求方程的根、求函数的定积分等。 非数值运算举例:人名排序,图书资料检索等. 三、简单算法举例 为了理解如何设计算法,下面举几个算法的简单例子。 [例1] 有两个杯子A和B,分别盛有果汁和酒,要求将这两个杯子进行互换。 (请学生回答,并要求说清楚明确的步骤) 学生所回答的步骤就是算法的描述: 根据常识,必须增加一个空杯C作为过渡。 其算法表示 步骤1:先将A杯中的果汁倒在C杯中; 步骤2:再讲B杯中的酒倒在A杯中; 步骤3:最后将C杯中的果汁倒在B杯中。 此问题可以抽象为数值运算中的交换两个变量的值,简化为: ①A → C ②B → A ③C → B [例2] 从十个数中挑选出最大的数。 创设情景:这个问题的思路可以用“打描台”来比喻。第一个同学先上讲台,然后第二个同学上去比试,胜者(个子高的)留在讲台上,依次轮流,一直到第十个人比完为止()一共九次)最后留在讲台上的同学就是胜者(个子最高的同学)。 算法描述: 1.先任选一个数放在变量A中; 2.将第二个数与变量A中的数进行比较,大者放在变量A中; 3.再将第三个数与变量A中的数进行比较,大者放在变量A中; 10.最后将第十个数与变量A中的数进行比较,大者放在变量A中。 这样写算法虽然正确,但是太烦琐了,可以简化为如下: 1.数X → A,计数器 0 → N; 2.下一个数Y与A比较,大者→ A; 3.N + 1 → N;(增加一次比较次数) 4.若N ? 9,执行第2步,否则停止循环,此时A中的数最大。 显然,用“循环”表示的算法比较简练。 如果题目要求改为“从1000个数中挑选最大者”,只许需要将算法里面的第4步中的“9”改为“999”即可。 [例3] 求两个正整数m和n的最大公约数。 解题之前介绍“辗转相除法”求最大公约数的方法。“辗转”就字面意思来讲是翻来覆去的意思,因此“辗转相除法”的.格式可以形象地表示为: 将m和n赋具体值,m = 60,n = 14,板书具体求解方法。 用m 作被除数, n 作除数,r 做余数。 具体方法(算法)为: ①求m/n的余数r; ②若r = 0 ,则n为最大公约数,若r ≠ 0,执行第③步; ③将n → m,将r → n中; ④返回重新执行第①步。 注意:如果事先不知道M,N两个数谁大谁小,应(可)在第一步之前增加一个步骤,比较一下两个数的大小,大数在m中,小数在n中。 四、算法的特性 1、有穷性:一个算法应该包含有限个操作步骤,而不能是无限的。 2、确定性:算法的每个步骤都应该是明确无误的,不能含义模糊,使执行者无所适从。 3、有零个或者多个输入 4、有一个或者多个输出 5、有效性:算法中的每一步都应该能有效地执行,执行算法最后应该能得到确定的结果。 五、归纳总结 算法的概念; 算法的描述; 算法的特性: 有穷性:包含有限的操作步骤 确定性:算法中的每一个步骤都应当是确定的 有零个或多个输入:输入是指在执行算法时需要从外界取得必要的信息 有一个或多个输出:算法的目的是为了求解,“解” 就是输出 有效性:算法中的每一个步骤都应当能有效地执行,并得到确定的结果 。 对于程序设计人员来说,我们不仅要会使用现成的算法,还要会设计算法,即要设计出算法中的每一个步骤。 六、 练习 ①用辗转相除法求324和180的最大公约数。 七、板书设计 |
随便看 |
|
范文网提供海量优质实用美文,包含随笔、日记、古诗文、实用文、总结、计划、祝福语、句子、职场文档等范文,为您写作提供指导和优质素材。