C语言第5章循环结构程序设计.ppt_第1页
C语言第5章循环结构程序设计.ppt_第2页
C语言第5章循环结构程序设计.ppt_第3页
C语言第5章循环结构程序设计.ppt_第4页
C语言第5章循环结构程序设计.ppt_第5页
已阅读5页,还剩42页未读 继续免费阅读

VIP免费下载

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第5章循环结构程序设计,_主讲教师:姜毅,2019/11/19,1,章节知识点:,5.1while语句与dowhile语句5.2for循环语句5.3循环嵌套语句5.4break语句及continue语句的应用,2019/11/19,2,笔试部分,2019/11/19,3,上机部分,2019/11/19,4,循环结构是结构化程序设计的三种基本结构之一,也是最重要、最常用的一种基本结构。其特点是:在给定条件成立时,反复执行某程序段,直到给定条件不成立时为止。给定的条件称为循环条件,反复执行的程序段称为循环体。,循环结构概述:,2019/11/19,5,2019/11/19,6,循环结构也称重复结构:程序中反复执行的一组指令或程序段。,循环体:被反复执行的程序段。,循环变量:用来控制循环是否继续进行的变量。循环结构有两种类型即当型循环和直到型循环。,方框图及执行过程:,2019/11/19,7,5.1while语句与dowhile语句,由while语句构成的循环也称”当”循环。一般形式如下:while(表达式)循环体语句,while循环流程图,2019/11/19,8,2019/11/19,9,while语句的说明:,(1)while语句属当型循环,即先判断条件(表达式),再执行循环体。,(2)表达式为一条件,用于控制循环是否可继续执行,故称控制表达式。,(3)语句A为内嵌式语句,是循环结构的循环体。它可以是单语句也可以是复合语句,且该语句中必须包含有对循环条件进行修改的语句。,2019/11/19,10,例5.1:编程求1+2+3+100的值。,分析:求和的过程为:,1)S=1S1=S0+12)S=1+2S2=S1+23)S=1+2+3S3=S2+3100)S=1+2+100S100=S99+100,S0=0,求和表达式:,S=S+i,初值:,S=0,循环次数i:,1100,2019/11/19,11,流程图:,程序:,main()ints,i;s=0,i=1;while(i=100)s+=i;i+;printf(s=%ldn,s);,注意:,如果循环体中包含一个以上的语句,应该用花括弧括起来,以复合语句的形式出现。如果不加花括弧,则while语句的范围只到while后的第一个分号处。,在循环体中应该有使循环趋向结束的语句,否则会导致死循环。,如上例中的语句改写成如下形式:i=1;while(i=100)s+=i;i+;,则while语句的循环体语句为:s+=i;循环变量i的值没有改变,循环不能终止,陷入死循环,5.2do-while语句构成的循环,由do-while语句构成的循环称为”直到型”循环,do-while语句的一般形式为:do循环体语句while(表达式);,2019/11/19,13,2019/11/19,14,执行内嵌语句A,再判断表达式(条件)若为真,则继续执行内嵌语句A,再判断表达式(条件),直到表达式的值为假时,执行do-while后面的语句。,执行过程:,与while语句的不同:,do-while语句至少执行循环体一次,但while语句当条件为假时不执行循环体语句。,2019/11/19,15,例:while与do-while区别,includemain()inti=65;doputchar(i);i+;while(iA);,includemain()inti=65;while(iA)putchar(i);i+;,无输出,输出A,例5.2:编程求1+2+3+100的值。,2019/11/19,16,#include“stdio.h”voidmain()ints,i;s=0;i=1;dos+=i;i+;while(i=100);printf(s=%ldn,s);,5.2for循环语句,一般形式为:for(表达式1;表达式2;表达式3)循环体语句,在所有循环语句中for语句使用最为灵活,它完全可以取代while语句。,2019/11/19,17,各部分的作用:表达式1:循环变量赋初值。表达式2:判断循环条件,若省略,则认为循环条件恒为“真”。表达式3:修改循环变量的值。语句:循环体,2019/11/19,18,说明:for语句的一般形式中的“表达式1”可以省略。此时应该在for语句之前给循环变量赋初值。如果表达式2省略,即不判断循环条件(认为表达式始终为真),循环会无终止的运行下去。表达式3省略时,应另外设置条件保证循环能正常结束。如在循环体内修改循环变量。,2019/11/19,19,说明:表达式1和表达式3可以是简单的表达式,也可以是一个逗号表达式;它可以与循环变量有关,也可以与循环变量无关。循环体如果有多条语句,必须用大括号括起来。以上三个表达式在语法上都可以省略,但分号不能省,例如:for(;)。循环条件表达式一般是关系表达式或逻辑表达式,它的判断依据依然是看最后结果,结果为0,循环结束,不为0,循环继续。,2019/11/19,20,如:for(i=1;i+)sum=sum+i;,它相当于:i=1;while(1)sum=sum+i;i+;,该循环是死循环,如:for(i=1;i100;)sum=sum+i;i+;,在循环体内修改循环变量,循环可以正常终止,相当于:while(i100)sum=sum+i;i+;,如:for(;i100;)sum=sum+i;i+;,(1)在循环语句前给循环变量赋初值(2)循环体内修改循环变量,2019/11/19,21,例:for(y=20,x=1;x-y;x+=x)printf(%d,%dn,x,y);,该语句输出如下:,1,192,184,178,16,例5.4:用for语句求1+2+3+100的和。,main()inti,sum=0;for(i=1;i=100;i+)sum=sum+i;printf(“sum=%dn”,sum);,2019/11/19,22,2019/11/19,23,例:求n!,分析:求阶乘的过程为:,1)S=1S1=S012)S=12S2=S123)S=123S3=S23n)S=12nSn=Sn-1100,S0=1,求阶乘表达式:,S=Si,初值:,S=1,循环次数i:,1n,2019/11/19,24,流程图:,程序:,#defineN10main()inti;longints=1;for(i=1;i=N;i+)s*=i;printf(s=%ldn,s);,2019/11/19,25,1.三种循环可以互相代替。2.for、while属当型循环,dowhile循环属直到型循环。3.在for循环的循环体中无须对循环变量进行修改,其它两种循环则必须在循环体中对循环变量进行修改。4.for循环的初始条件可在表达式1中进行设置,其它两种循环则必须在进入循环之前进行设置。,三种循环几点说明:,2019/11/19,26,例:求水仙花数,即这个数等于它的百位、十位和个位数的立方和。如153是一个水仙花数,因为153,分别用三种循环语句编写该程序。,2019/11/19,27,#includevoidmain()intn=100,i,j,k;/*i、j、k用来放这个数的百位、十位和个位*/printf(水仙花数是:);while(n1000)i=n/100;j=(n/10)%10;k=n%10;if(n=i*i*i+j*j*j+k*k*k)printf(%6dn,n);n=n+1;,2019/11/19,28,#includevoidmain()intn=100,i,j,k;printf(“水仙花数是:”);doi=n/100;j=(n/10)%10;k=n%10;if(n=i*i*i+j*j*j+k*k*k)printf(%6d,n);n=n+1;while(n1000);,2019/11/19,29,#includevoidmain()intn=100,i,j,k;printf(“水仙花数是:”);for(n=100;n100)break;printf(sum=%dn,sum);,例:,2019/11/19,32,5.4.2continue语句continue是继续的意思,所以continue语句的功能就是跳过循环中剩余的语句而继续执行下一次循环。continue语句只能用在循环语句中,用在其它语句中没有任何作用。,2019/11/19,33,continue语句只用于循环结构的内部,常与if语句联合起来使用,以便在满足条件时提前结束本次循环。,2019/11/19,34,例对除5的倍数以外的1100的数求和。,main()inti,s;s=0;for(i=1;i=100;i+)if(!(i%5)continue;s+=i;printf(“%d,%dn”,i,s);,如果if判断语句为真,则跳出本次循环,回到循环条件,判断是否进行下一次循环,此处,当i为5的倍数时,!(i%5)为真,跳出本次循环,不执行continue下面的语句,直接进入下一次循环,即执行for语句,运行序列如下:iif(!(i%5)si1假s=0+1=12假s=1+2=33假s=3+3=64假s=6+4=105真不执行6假s=10+6=16,main()inti;for(i=1;i100;i+)if(i%7!=0)continue;/*不能整除7就跳出本次循环*/printf(“%d”,i);,例:,2019/11/19,35,break语句跳出本层循环break语句只能向外跳出一层,例如在循环语句中嵌套了switch语句,而break在switch语句中,那么它只能跳出switch语句,而循环还要继续。如果在循环嵌套语句中,break也是只能向外跳出一层。,continue跳出本次循环而继续执行本层循环中的下一次循环。,小结:,2019/11/19,36,我们称在一个循环体的内部包含了另外一个完整的循环结构成为循环结构的嵌套。内嵌的循环结构中还可以继续嵌套循环(即为多层循环)。每一层循环结构在逻辑上都必须是完整的。通常把里面带的循环称为“内循环”,外面的循环称为“外循环”。,5.4循环嵌套语句,2019/11/19,37,说明:嵌套的原则:不允许交叉循环与分支可以相互嵌套但不允许交叉。,3种循环结构(for循环、while循环、do-while循环)可以相互嵌套。需要理解的是,内层的循环在语法上是外层循环的循环体的一部分。因此,外层循环每进行一轮,内层循环要一直循环到结束。,while(表达式1)for(表达式1;表达式2;表达式3),例如:,2019/11/19,38,2019/11/19,39,*,输出图形:,for(i=1;i=4;i+)printf(“*”);printf(“n”);,2019/11/19,40,其中语句:printf(“*”);等价于,for(j=1;j=8;j+)printf(“*”);,于是构成了二重循环语句:,for(i=1;i=4;i+)for(j=1;j=8;j+)printf(“*”);printf(“n”);,2019/11/19,41,上面的例子中:外循环由外循环控制变量i控制,i由1递增到4。,for(i=1;i=4;i+)for(j=1;j=8;j+)printf(“*”);printf(“n”);,每1次的外循环中,都要执行由内循环控制变量j控制的8次内循环操作和1次换行操作。,由此:每次内循环输出一个星号,外循环输出一行(8个)星号,4次外循环,输出了4行8列星号。,2019/11/19,42,例输出九九乘法表,1*1=11*2=22*2=41*3=32*3=63*3=91*9=92*9=189*9=81,2019/11/19,43,main()inti,j;for(i=1;i=9;i+)for(j=1;j=i;j+)printf(%d*%d=%2d,i,j,i*j);printf(n);,程序:,2019/11/19,44,例输出如下图形:,*,2019/11

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论