《循环控制结构》PPT课件.ppt
《《循环控制结构》PPT课件.ppt》由会员分享,可在线阅读,更多相关《《循环控制结构》PPT课件.ppt(94页珍藏版)》请在三一办公上搜索。
1、,第6章,循环控制,循环是计算机解题的一个重要特征。由于计算机运 算速度快,最适宜做重复性的工作。当我们在进行程序 设计时,总是要把复杂的不易理解的求解过程转换为容 易理解的操作的多次重复,从而降低了问题的复杂度,同时也减少程序书写及输入的工作量。,sum=1+2+3+4+100输出如下:输出所有210000的素数.,*,循环结构程序设计,循环是在循环条件为真时计算机反复执行的一组指令(循环体)。循环控制通常有两种方式:计数控制事先能够准确知道循环次数时用之 用专门的循环变量来计算循环的次数,循环变量的值在每次执行完循环体各语句后递增,达到预定循环次数时则终止循环,继续执行循环结构后的语句。标
2、记控制事先不知道准确的循环次数时用之 由专门的标记变量控制循环是否继续进行。当标记变量的值达到指定的标记值时,循环终止,继续执行循环结构后的语句。,实现循环结构的语句,C语言中可用以下语句构成循环:if goto while do while for其中if goto是通过编程技巧(if语句和goto语句组合)构成循环功能。而且goto语句将影响程序流程的模块化,使程序可读性变差,所以结构化程序设计主张限制goto语句的使用。其他三种语句是C语言提供的循环结构专用语句。,6.1 if/goto 语句,语句功能:,语句格式:,语句标号:语句;if(表达式)goto 语句标号;,当(表达式)的值为
3、非零时则重复执行“语句标号”后面的语句。,标识程序中某 个语句的位置,EXAMPLE6-1:,请用C语言实现右侧程序流程图所描述的算法:即:sum=1+2+3+4+100,设:i 计数器:i=i+1,sum 为累加器:sum=sum+i,main(),int sum=0,i=1;,sum=sum+i;,sum+=i;,i=i+1;,if(i=100),printf(“%dn”,sum);,goto aa;,aa:,i+;,语句标号:语句;if(表达式)goto 语句标号;,EXERCISES6-1:,从键盘输入100个有符号整数,请 分别统计其中正整数和负整数的个数。,Begin,i=0 p=
4、0 n=0,i+,输出p n,End,p+,F,X0,T,输入 x,n+,i100,F,1,1,1、设计算法,X0,2、实现算法,main(),Int p,n,i,x;,scanf(“%d”,i+;,if(x0),printf(“%d,%dn”,p,n);,goto bb;,bb:,p+;,p=n=i=0;,else,If(x0)n+;,if(i100),5.2 while 语句,语句功能:,语句格式:,while(表达式)statements;,当表达式的值为非零时,重复statements。,关系、逻辑 赋值表达式,body of loop,请用while实现 sum=1+2+3+4+10
5、0,main(),int sum=0,i=1;,sum+=i;,While(i=100),printf(“%dn”,sum);,i+;,while(表达式),main()int n=0;while(n3)printf(“%d,”,n);n+;printf(“%dn”,n);,0,main()int n=3;while(n)printf(“%d,”,n-);n=-3;printf(“n”);while(n)printf(“%d,”,n+);,1,2,3,3,2,1,-3,-2,-1,EXAMPLE6-2:,n,0,1,2,3,2,1,0,-3,-2,-1,0,main()int a=1,b=2,
6、c=2,t=0;while(ab)t=a;a=b;b=t;c+;printf(“%d,%d,%d”,a,b,c);,EXERCISES6-2:,a,0,2,2,1,b,c,t,1,2,1,3,main()int x=0,s=0;while(!x!=0)s+=+x;printf(“%d n”,s);,EXERCISES6-3:,x,0,s=s+(+x);,s,0,1,1,!x,从键盘输入100条整型数据,请找出其中最大的数,并指出这个最大的数是从键盘第几次输入的。要求:1、用N-S图设计算法;2、用C语言实现算法。,HOMEWORK6-1:,请分别统计在输入的字符串中 字母、数字和其它字符的个数
7、。要求:1、用N-S图设计算法;2、用C语言实现算法。,HOMEWORK6-2:,book12pen5%*#()&,字母:,7,数字:,3,字符:,8,语句功能:,6.3 do-while 语句,语句格式:,do statements;while(表达式);,当表达式的值为非零时,重复statements。,body of loop,1+2+3+4+5+100,main()int i,sum;,do,printf(“%dn”,sum);,sum=0;i=1;,i+;,while();,sum+=i;,while(i=100);,EXAMPLE6-3:,main()int x;x=-1;do x
8、=x*x;while(!x);,EXERCISES6-4:,A)是死循环 B)循环执行三次C)循环执行一次D)有语法错误,x=0;,main()int x=3;do printf(“%d,”,x-=2);while(!(-x);,EXERCISES6-5:,A)1 B)1,-2 C)3,0 D)0,x,3,1,0,-2,-3,x=x-2;,main()int s;s=7;do s=2;while(s0);printf(“s=%dn”,s);,EXERCISES6-6:,请写出右侧程序的运行结果,main()int x,y;x=y=0;while(x20)y+,x+=3;printf(“y=%d
9、 x=%dn”,y,x);,EXERCISES6-7:,写出右侧程序段的运行结果以及循环体中的语句共执行了几次。,为了使电文保密,往往按一定规律将其转换成 密码,收报人再按约定的规律将其译回原文。例如,可以按以下规律将电文变成密码:将字母A变成字母E(a变e,即将变成其后的第4 个字母)W变成字母A,X变成字母B,Y变成字母C,Z 变成字母D。要求:字母按上述规律转换,非字母字符不变。如,“China”应转换为“Glmre”。请输入一行字符,要求输出其相应的密码。,请设计一个 译密码 的程序,HOMEWORK6-3:,main()int x,y;x=y=0;do y+;x*=x;while(x
10、0),请程序的运行结果及循环次数,HOMEWORK6-4:,while语句和用do-while语句的比较:在一般情况下,用while语句和用do-while语句处理同一问题时,若二者的循环体部分是一样的,它们的结果也一样。但是如果while后面的表达式一开始就为假(0值)时,两种循环的结果是不同的。,例 while和do-while循环的比较(1)#include(2)#include void main()void main()int sum=0,i;int sum=0,i;scanf(“%d,,运行结果:1 sum=55 再运行一次:11sum=0,运行结果:1 sum=55 再运行一次:
11、11sum=11,说明:(1)当while后面的表达式的第一次的值为“真”时,两种循环得到的结果相同。否则,二者结果不相同。,语句功能:,6.4 for 语句,语句格式:,for(表达式1;表达式2;表达式3)statements;,当表达式2的值为非零时,重复执行statements。,for(表达式1;表达式2;表达式3)statements;,表达式1 循环初始表达式,用于进入循环体前为循环变量赋初值 由算术、赋值、逻辑和逗号表达式构成。,表达式2 循环控制表达式,用于控制循环体语句的执行次数由关 系表达式或逻辑表达式构成。,表达式3 修改循环变量表达式,即每循环一次使得表达式1的值 就
12、要变化一次。由算术、赋值、逻辑和逗号表达式构成。,main()int n;for(n=1;n=10;n+)printf(“%d,”,n);,1,2,3,4,5,6,7,8,9,10,for(表达式1;表达式2;表达式3)statements;,EXAMPLE6-4:,main()int n,i=100;for(n=1;n=5;n+)printf(“%d,”,i);,100,100,100,100,100,main()int n,i=100;for(n=5;n0;n-)printf(“%d,”,i);,EXAMPLE6-5:,main()int x,y;for(x=0,y=0;x+y=50;x+
13、,y+)printf(“%3d”,x+y);if(x%5=0)printf(“n”);,EXERCISES6-8:,写出右侧程序段的 运行结果,main()int sum,i;for(sum=0,i=1;i=100;i+)sum+=i;printf(“sum=%dn”,sum);,main()int sum=0,i=1;do sum+=i;i+;while(i=100);printf(“sum=%dn”,sum);,main()int sum=0,i=1;while(i=100)sum+=i;i+;printf(“sum=%dn”,sum);,main()int sum=0,i=1;label
14、:if(i=100)sum+=i;i+;goto label;printf(“sum=%dn”,sum);,1+2+3+4+5+100,说明:for语句的一般形式中的“表达式1”可以省略,此时应在 for语句之前给循环变量赋初值。注意省略表达式1时,其后的分号不能省略。如:for(;i=100;i+)sum=sum+i;执行时,跳过“求解表达式1”这一步,其他不变。,如果表达式2省略,即不判断循环条件,循环无终止地 进行下去。也就是认为表达式2始终为真。例如:for(i=1;i+)sum=sum+i;它相当于:i=1;while(1)sum=sum+1;i+;,(3)表达式3也可以省略,但此时
15、程序设计者应另外设法保证 循环能正常结束。如:for(i=1;i=100;)sum=sum+i;i+;在上面的for语句中只有表达式1和表达式2,而没有表达式3。i+的操作不放在for语句的表达式3的位置处,而作为循环体的一部分,效果是一样的,都能使循环正常结束。,(4)可以省略表达式1和表达式3,只有表达式2,即只给循环条件 如:for(;i=100;)while(i=100)sum=sum+i;sum=sum+i;i+;相当于 i+;在这种情况下,完全等同于while语句。可见for语句比while语句功能强,除了可以给出循环条件外,还可以赋初值,使循环变量自动增值等。,(5)3个表达式都
16、可省略,如: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,j=100;i=j;i+,j-)k=i+j;表达式1和表达式3都是
17、逗号表达式,即同时设两个初值,使两个变量增值。,在逗号表达式内按自左至右顺序求解,整个逗号表达式的值为其中最右边的表达式的值。如:for(i=1;i=100;i+,i+)sum=sum+i;相当于 for(i=1;i=100;i=i+2)sum=sum+i;,(7)表达式2一般是 关系表达式(如i=100)或逻辑表达式(如ab 在表达式2中先从终端接收一个字符赋给c,然后判断此赋值表达式的值是否不等于n(换行符),如果不等于n,就执行循环体。注意:此for语句的循环体为空语句,把本来要在循环体内处理的内容放在表达式3中,作用是一样的。,for(;(c=getchar()!=n;)printf(
18、“%c”,c);for语句中只有表达式2,而无表达式1和表达式3。其作用是每读入一个字符后立即输出该字符,直到输入一个“换行”为止。,例5.9 用for循环按下列公式计算e的值(精度为1e-6):e=1+1/(1!)+1/(2!)+1/(3!)+1/(n!)void main()int i,f=1;double e=0;x=1.0;for(i=1;x=1e-6;i+)e=e+x;f=f*i;x=1.0/f;printf(“e=%f”,e);,例5.10 猴子第一天摘下若干桃子,当即吃了一半,还不过瘾,又多吃了一个。第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃前一天剩下的一半
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 循环控制结构 循环 控制 结构 PPT 课件
![提示](https://www.31ppt.com/images/bang_tan.gif)
链接地址:https://www.31ppt.com/p-5583426.html