收藏 分享(赏)

数学苏教版《算法初步》讲练第9课时5.3.3循环语句(1).doc

上传人:无敌 文档编号:527281 上传时间:2018-04-09 格式:DOC 页数:3 大小:92KB
下载 相关 举报
数学苏教版《算法初步》讲练第9课时5.3.3循环语句(1).doc_第1页
第1页 / 共3页
数学苏教版《算法初步》讲练第9课时5.3.3循环语句(1).doc_第2页
第2页 / 共3页
数学苏教版《算法初步》讲练第9课时5.3.3循环语句(1).doc_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述

1、第 9 课时 5.3 基本算法语句重点难点重点:正确理解循环语句的概念,并掌握其结构;会应用循环语句编写程序;并能进行简单的综合应用。难点:理解循环语句的表示方法、结构和用法;会编写程序中的循环语句.【学习导航】 知识网络 循环语句当型循环语句 语 句语 句forwhile学习要求 1正确理解循环语句的概念,并掌握其结构;会应用循环语句编写程序;并能进行简单的综合应用。2理解并掌握循环语句在计算机程序语言中的作用,掌握两种循环语句应用的实例:数列求和、求积。【课堂互动】自学评价1问题:设计计算 的一个9753算法。【分析】将上述表达式看成 49个乘法,用公式表示为:SSIS初始为 1,I 为

2、1,将每次的乘积都赋予 S,I 从 1到 99,每次增加 2,公式 SSI 会被重复执行,这种执行过程可用循环结构表示。算法一:S1 S1;S2 I1;S3 II+2;S4 SSI;S5 如果 I小于 99,那么转 S3;S6 输出 S上述算法用流程图表示如下:【说明】算法一是先执行后判断的直到型循环结构,常用“Do”语句表示,我们不再学习。算法二:S1 S1;S2 I1;S3 当 I不大于 99时转 S4,否则转 S6;S4 SSI;S5 II+2;S6 输出 S上述算法用流程表示如图所示:【说明】算法二可以理解为:当 I99时, 才循环执行 S4和 S5两步,这种先判断后执行的循开始S1I

3、1SSII99开始YN输出 SII+2Y开始S1I1SSII99开始N输出 SII+2环结构我们称为当型循环,常用“While”语句和“For”语句表示,其中“While 语句”可以用如下代码表示:While 条件 P 成立要执行的语句 End While 用伪代码表示为:S1I1While I99SSIII+2End WhilePrint S由此可见,同一个问题可以用不同的循环方式来解决,直到型循环和当型循环的控制条件是不同的,请注意流程图中判断分支的流向条件。在算法二的伪代码中,可以看成 I 从 1到 99,每次增加 2,用 For语句写成 I From 1 To 99 Step 2, “

4、Step 2”意为 I 每次增加 2。写成一般形式为:注意黑体字部分是 For 循环语句的关键词,在“For”和“End For”之间的步骤称为循环体,如果省略“Step 2”,那么循环时 I 的值默认增加 1。上述问题用 For 循环语句的伪代码可以表示为:S1For I From 1 To 99 Step 2SSIEnd ForPrint S【总结】当循环的次数确定时,我们通常用 For 循环语句,而当循环的次数不确定时,我们通常用 While循环语句,这两种语句都是前测试语句,即先判断后执行。若初始条件不成立,则一次也不执行循环体中的内容,任何一种需要重复处理的问题都可以用这种前测试循环

5、来实现。【经典范例】例 1 分别用 While语句和 For语句写出求1+2+3+100的和的一个算法。【解】用伪代码表示为:S0For I From 1 To 100 SS+IEnd ForPrint S或:S0While I100SS+III+1End WhilePrint S【注意】在累加的算法中,S 的初始值一般设为 0,在累乘的算法中,S 的初始值一般设为1,为什么?例 2 问题:将前面的问题改为1 0000,那么,如何753寻找满足条件的最小整数呢?请用伪代码写出一个算法。【分析】这个问题中,因为不知道循环需要进行的次数,所以不能用 For循环语句。【解】算法:S1 S1;S2 I

6、1;S3 如果 S10000,那么II+2,SSI,重复 S3;S4 输出 I。上述算法可以理解为:当 S10000 时,循环执行 S3。伪代码如下:S1;I1While S10000SSIII+2End WhilePrint I在“For”语句中,I 的变化是通过“Step”设置的,在程序运行时自动改变,所以循环体中没有如“II+2”这样的语句,而在“While ”语句中,则需要手工编写如For I From“初值” To “终值” Step “步长”End For“II+2”这样的代码以控制程序的运行,避免出现“死循环” 。例 3 抛掷一枚硬币时,既可能出现正面,也可能出现反面,预先做出确

7、定的判断是不可能的,但是假如硬币的质量均匀,那么当抛掷次数很多时,出现正、反面的机率都应接近于 50%,试设计一个循环语句模拟抛掷硬币的过程,并计算抛掷中出现正面的机率。分析:抛掷硬币的过程实际上是一个不断重复的地做同一件事情的过程,这样的过程我们可以通过循环语句模拟。在程序语言中,有一个随机函数“Rnd”,它能产生 0 与 1 之间的随机数,这样,我们可以用大于 0.5 的随机数表示出现正面,不大于 0.5 的随机数表示出现反面,【解】用伪代码表示为:S0 求累计和,初始值设为 0Read nFor I From 1 To nIf Rnd0.5 Then SS+1End ForPrint 出

8、现正面的频率为 s单行条件语句不需要结束标志“End If”追踪训练1.下面的伪代码中, “For”语句的循环体是_【解】循环体是S2S+3,If S20 Then SS-20 End If2.我们曾研究过问题 3212 004,试用“While”语句描述这一问题的算法过程。【解】S0I1While S2004SS+III+1End WhilePrint I3.2000年我国人口数约为 13亿,如果每年的人口自然增长率为 15,那么多少年后我国人口数将达到或超过 15亿?这个问题可通过循环方式计算完成,即每一次在原有的基础上增加 15,直到达到或超过 15亿,再记下循环次数,试用循环语句表示这一过程。【解】s1300000000i0while s1500000000ss(1+0.015)ii+1End WhilePrint i4. 1,1,2,3,5,8,13,这一列数的规律是:第 1、第 2个数是 1,从第 3个数起,该数是其前面 2个数之和,试用循环语句描述计算这列数中前 20个数之和的算法.【解】a1b1S2For n From 3 To 20ca+bSS+cabbcEnd ForPrint SS0For I From 1 To 11 Step 2S2S+3If S20 ThenSS-20End IfEnd ForPrint S

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 中等教育 > 小学课件

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报