程序设计(第二版)ppt教学课件第6章循环控制

上传人:bin****86 文档编号:57166769 上传时间:2018-10-19 格式:PPT 页数:65 大小:515.50KB
返回 下载 相关 举报
程序设计(第二版)ppt教学课件第6章循环控制_第1页
第1页 / 共65页
程序设计(第二版)ppt教学课件第6章循环控制_第2页
第2页 / 共65页
程序设计(第二版)ppt教学课件第6章循环控制_第3页
第3页 / 共65页
程序设计(第二版)ppt教学课件第6章循环控制_第4页
第4页 / 共65页
程序设计(第二版)ppt教学课件第6章循环控制_第5页
第5页 / 共65页
点击查看更多>>
资源描述

《程序设计(第二版)ppt教学课件第6章循环控制》由会员分享,可在线阅读,更多相关《程序设计(第二版)ppt教学课件第6章循环控制(65页珍藏版)》请在金锄头文库上搜索。

1、6.1 概述 6.2 goto语句以及用goto语句构成循环 6.3 while语句 6.4 do while语句 6.5 for 语句 6.6 循环的嵌套 6.7 几种循环的比较 6.8 break语句和continue语句 6.9 程序举例 习题,第6章 循 环 控 制,6.1 概述,在许多问题中需要用到循环控制。例如,要输入全校学生成绩;求若干个数之和;迭代求根等。几乎所有实用的程序都包含循环。循环结构是结构化程序设计的基本结构之一,它和顺序结构、选择结构共同作为各种复杂程序的基本构造单元。 因此熟练掌握选择结构和循环结构的概念及使用是程序设计的最基本的要求。(1) 用goto语句和if

2、语句构成循环;(2) 用while语句;(3) 用do|while语句;(4) 用for语句。 在下面各节中将分别作介绍。,6.2 goto语句以及用goto语句构成循环,goto语句为无条件转向语句,它的一般形式为goto语句标号; 语句标号用标识符表示,它的定名规则与变量名相同,即由字母、数字和下划线组成,其第一个字符必须为字母或下划线。不能用整数来做标号。例如:goto label-1; 是合法的,而goto 123; 是不合法的。结构化程序设计方法主张限制使用goto语句,因为滥用goto语句将使程序流程无规律、,可读性差。但也不是绝对禁止使用goto语句。一般来说,可以有两种用途:

3、(1) 与if语句一起构成循环结构; (2) 从循环体中跳转到循环体外,但在c语言中可以用break语句和continue语句(见6.8节)跳出本层循环和结束本次循环。goto语句的使用机会已大大减少,只是需要从多层循环的内层循环跳到外层循环外时才用到goto语句。但是这种用法不符合结构化原则,一般不宜采用,只有在不得已时(例如能大大提高效率)才使用。,例6.1用if语句和goto语句构成循环,求n。此问题的算法是比较简单的,可以直接写出程序:main( ) int i, sum=0; i=1; loop: if(i=100) sum=sum+i;i+;goto loop;printf(“%d

4、“,sum);,100 n=1,运行结果如下: 5050 这里用的是“当型”循环结构,当满足“i=100” 时执行花括弧内的循环体。请读者自己画出流程图。6.3 while语句while语句用来实现“当型”循环结构。其一般形式如下: while (表达式) 语句,当表达式为非0值时,执行while语句中的内嵌语句。其流程图见图6.1。其特点是:先判断表达式,后执行语句。,图6.1,图6.2,例6.2求n。用传统流程图和NS结构流程图表示算法,见图6.2(a)和图6.2(b)。 根据流程图写出程序: main()int i,sum=0;i=1;while (i100”,因此在循环体中应该有使i增

5、值以最终导致i100的语句,今用“i+;”语句来达到此目的。如果无此语句,则i的值始终不改变,循环永不结束。,6.4 do while语句 do while语句的特点是先执行循环体,然后判断循环条件是否成立。其一般形式为 do 循环体语句while (表达式); 它是这样执行的:先执行一次指定的循环体语句,然后判别表达式,当表达式的值为非零(“真”) 时,返回重新执行循环体语句,如此反复,直到表达式的值等于0为止,此时循环结束。可以用图6.3表示其流程。请注意dowhile循环用NS流程图的表示形式(图6.3(b)。,图6.3,例6.3用dowhile语句求n。 先画出流程图,见图6.4。,图

6、6.4,图6.5,100 n=1,程序如下: main()int i,sum=0;i=1;do sum=sum+i;i+;while( i10时,二者结果就不同了。这是因为此时对while循环来说,一次也不执行循环体(表达式“i10时,二者结果就不同了。这是因为此时对while循环来说,一次也不执行循环体(表达式“i100”。因为“当i100时继续执行循环”和“直到i100结束循环”是对同一问题的两种表述方式。千万不要在图5|4(b)中写成“直到i100”。,6.5 for 语 句 C语言中的for语句使用最为灵活,不仅可以用于循环次数已经确定的情况,而且可以用于循环次数不确定而只给出循环结束

7、条件的情况,它完全可以代替while语句。for语句的一般形式为 for(表达式1;表达式2;表达式3) 语句它的执行过程如下:(1) 先求解表达式1。(2) 求解表达式2,若其值为真(值为非0),则执行for语句中指定的内嵌语句,然后执行下面第(3)步。若为假(值为0),则结束循环,转到第(5)步。,(3) 求解表达式3。(4) 转回上面第(2)步骤继续执行。(5) 循环结束,执行for语句下面的一个语句。可以用图6.6来表示for语句的执行过程。 for语句最简单的应用形式也就是最易理解的如下形式:,图6.6,for(循环变量赋初值;循环条件;循环变量增值) 语句 例如: for(i=1;

8、i=100;i+) sum=sum+i; 它的执行过程与图6.2完全一样。可以看到它相当于以下语句:i=1;while(i=100)sum=sum+i;i+;,显然,用for语句简单、方便。对于以上for语句的一般形式也可以改写为while循环的形式: 表达式1; while(表达式2)语句表达式3; 说明: (1) for语句的一般形式中的“表达式1”可以省略,此时应在for语句之前给循环变量赋初值。注意省略表达式1时,其后的分号不能省略。如for(;i=100;i+) sum=sum+i;执行时,跳过“求解表达式1”这一步,其他不变。 (2) 如果表达式2省略,即不判断循环条件,循环无终止

9、地进行下去。也就是认为表达式2始终为真。见图6.7。,图6.7,例如: for(i=1; ;i+) sum=sum+i; 表达式1是一个赋值表达式,表达式2空缺。它相当于:i=1;while(1)sum=sum+1;i+; (3) 表达式3也可以省略,但此时程序设计者应另外设法保证循环能正常结束。如:,(4)可以省略表达式1和表达式3,只有表达式2,即只给循环条件,如: for(;i=100;) while(i=100)sum=sum+i; 相当于 sum=sum+i;i+; i+; 在这种情况下,完全等同于while语句。可见for语句比while语句功能强,除了可以给出循环条件外,还可以赋

10、初值,使循环变量自动增值等。 (5)三个表达式都可省略,如: for(;) 语句 相当于 while(1)语句。,即不设初值,不判断条件(认为表达式2为真值),循环变量不增值。无终止地执行循环体。 (6) 表达式1可以是设置循环变量初值的赋值表达式,也可以是与循环变量无关的其他表达式。如: for (sum=0;i=100;i+) sum=sum+i; 表达式3也可以是与循环控制无关的任意表达式。表达式1和表达式3可以是一个简单的表达式,也可以是逗号表达式,即包含一个以上的简单表达式,中间用逗号间隔。如: for(sum=0,i=1;i=100;i+) sum=sum+i; 或 for(i=0

11、,j=100;i=j;i+,j-) k+=i*j;,表达式1和表达式3都是逗号表达式,各包含两个赋值表达式,即同时设两个初值,使两个变量增值,执行情况见图6.8。在逗号表达式内按自左至右顺序求解,整个逗号表达式的值为其中最右边的表达式的值。如: for(i=1;i=100;i+,i+) sum=sum+i; 相当于 for(i=1;i=100;i=i+2) sum=sum+i;,。,图6.9,图6.8,(7) 表达式一般是关系表达式(如i=100)或逻辑表达式(如ab 在表达式2中先从终端接收一个字符赋给c,然后判断此赋值表达式的值是否不等于n(换行符),如果不等于n,就执行循环体。此for语

12、句的执行过程见图6.9,它的作用是不断输入字符,将它们的ascII码相加,直到输入一个“换行”符为止。 注意:此for语句的循环体为空语句,把本来要在循环体内处理的内容放在表达式3中,作用是一样的。可见for语句功能强,可以在表达式中完成,本来应在循环体内完成的操作。 for( ;(c=getchar()!=n;)printf(“%c“,c); 只有表达式2,而无表达式1和表达式3。其作用是每读入一个字符后立即输出该字符,直到输入一个“换行”为止。请注意,从终端键盘向计算机输入时,是在按Enter键以后才送到内存缓冲区中去的。运行情况: computer (输入) computer (输出) 而不是 ccoommppuutteerr,

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > PPT模板库 > PPT素材/模板

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号