《C语言循环结构一章ppt课件.ppt》由会员分享,可在线阅读,更多相关《C语言循环结构一章ppt课件.ppt(41页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、第五章循环结构1、用goto语句和if语句构成循环。2、用while语句。3、用do-while语句。4、用for语句。If语句和goto语句构成的循环n一般形式:goto语句标号;n作用:无条件转向语句标号处执行n语句标号:合法的标识符后面加个冒号”:”n语句标号必须于此goto语句在同一个函数中ngoto语句不符合结构化程序设计准则,因为无条件转向使程序结构无规律、可读性差。一般应避免使用goto语句,但如果能大大提高程序的执行效率,也可以使用。Example5_11.#include2.main()3.intx;4.x=3;5.ab:x+=2;/*ab:语句标号只能写在语句行的最左边*/
2、6.if(x20)7.gotoab;8.printf(%dn,x);9.while语句n一般形式:一般形式:while(表达式表达式)语句语句n作用:作用:实现“当型”循环。当“表达式”非0(真)时,执行“语句”。“语句”是被循环执行的程序,称为“循环体”。n特点:特点:先判“表达式(条件)”。注意事项nwhile后面的”()”不能少n表达式的可以使任意合法的表达式n语句的位置上只能有一条语句,while语句范围只到while后面第一个分号处。超过一条用“”括起来nwhile语句的循环体可能一次都不执行n循环体中必须有使循环趋于结束的语句,否则程序进入“死循环”(不结束)。求1100的累计和。
3、根据已有的知识,可以用“1+2+100”来求解,但显然很繁琐。现在换个思路来考虑:首先设置一个累计器sum,其初值为0,利用sum+=n来计算(n依次取1、2、100),只要解决以下3个问题即可:(1)将n的初值置为1;(2)每执行1次“sum+=n”后,n增1;(3)当n增到101时,停止计算。此时,sum的值就是1100的累计和。Example5_2计算#includemain()inti,sum=0;i=1;while(i=100)sum=sum+i;i+;printf(%d,sum);nExample5_3输入两个整数x和y,计算x和y之间所有的偶数之和main()intx,y,sun
4、,t;printf(”请输入两个整数(前大后小):”);scanf(”%d%d”,&x,&y);printf(”%d和%d之间所有的偶数的和是:”,x,y);while(xy)if(x%2=0)sum+=x;x+;printf(”%dn”,sum);dowhile语句n一般格式:do语句(循环体)while(表达式);n特点:“直到型”循环结构。先执行一次“语句”,判“表达式”,当“表达式”非0,再执行“语句”,直到“表达式”为0,循环结束。dowhile注意点ndo后面没有分号;n语句的位置上只能到第一个分号处,也就是只能有一条语句,超过用构成复合语句n表达式可以是任意表达式nExample
5、5_4计算计算n以内所有能被以内所有能被3整除或者能被整除或者能被7整除的整除的自然数之和自然数之和/*从3开始,各个自然数i逐个进行比较,直到自然数i不小于n则循环结束*/#includestdio.hmain()intn,i,s;printf(请输入一个整数:);scanf(%d,&n);/*输入一个整数给n*/s=0;/*s用来存放满足条件的自然数之和,和的初值为0*/i=3;/*从3开始*/doif(i%3=0|i%7=0)/*余数为0表示整除*/s+=i;i+;/*准备判断下一个自然数*/while(in);/*in表示条件成立,循环执行*/printf(s=%dn,s);n nwh
6、ile和do-while循环的比较main()inti,s=0;scanf(“%d”,&i);dos=s+i;i+;while(i=10);printf(“s=%d”,s);运行情况如下:main()inti,s=0;scanf(“%d”,&i);while(i=10)s=s+i;i+;printf(“s=%d”,s);运行情况如下:说明n在一般情况下,用while和do-while语句解决同一问题时,若二者的循环体部分是一样的,它们的结果也一样。但当while后面的“表达式”一开始就为“假”时,两种循环的结果不同。这是因为此时while循环的循环不被执行,而do-while循环的循环体被执行
7、一次。for语句n一般格式for(表达式(表达式1;表达式;表达式2;表达式;表达式3)语句语句 循环变量赋初值循环条件循环变量增量循环体部分执行过程:(1)求表达式1;(2)求表达式2,若为“真”,执行“语句”;若为假,转第(5)步。(3)求表达式3。(4)转第(2)步。(5)执行for语句下面的语句。nExample5_5计算计算n以内所有自然数之和以内所有自然数之和#includestdio.hmain()intn,i,s;printf(请输入一个整数请输入一个整数:);scanf(%d,&n);/*输入一个整数给输入一个整数给n*/s=0;/*s存储和存储和,初值为初值为0*/for(
8、i=0;in;i+)s+=i;printf(s=%dn,s);for(i=0;in;i+)s+=i;等等价价于于i=0;while(in)s+=i;i+;for语句说明(1)for语句中条件测试总是在循环开始时进行;如果循环体部分是多个语句组成的,则必须用左、右花括号括起来,使其成为一个复合语句。(2)for语句中的表达式1和表达式3即可以是一个简单的表达式,也可以是逗号连接的多个表达式,此时的逗号作为运算符使用。如:for(s=0,i=1;i=100;i+)s=s+i;或:for(i=1,j=100;i=j;i+,j-)k=i+j;在逗号表达式内按自左至右顺序求解,整个逗号表达式的值为其中最
9、右边的表达式的值。如:for(i=1;i=100;i+,i+)s=s+i;相当于:for(i=1;i=100;i=i+2)s=s+i;(3)for语句的一般形式中的“表达式1”可以省略,此时应在for语句之前给循环变量同赋初值。注意省略表达式1时,其后的分号不能省略。如:for(;i=100;i+)s=s+i;执行时,跳过“解表达式1”这一步,其它不变。(4)如果表达式2省略,即不判断循环条件,循环无终止地进行下去。也就是认为表达式2始终为真。例如:for(i=1;i+)s=s+i;相当于:i=1;while(1)s=s+I;i+;(5)表达式3也可以省略,但此时程序设计应另外设法保证循环能正
10、常结束。如:for(i=1;i=100;)s=s+I;i+;(6)可以省略表达式1和表达式3,只有表达式2,即只给循环条件。例:for(;i=100;)s=s+i;i+;相当于:while(i=100)s=s+i;i+;(7)3个表达式都可以省略,如:for(;)语句相当于:while(1)语句即不设初值,不判断条件(认为表达式2为真值),循环变量不增值,无终止地执行循环体。(8)表达式1可以是设置循环变量初值的赋值表达式,也可以是与循环变量无关的其它表达式。如:for(s=0;i=100;i+)s=s+i;表达式3也可以是与循环控制无关的任意表达式。(9)表达式2一般是关系表达式(如i=10
11、0)或逻辑表达式(如ab&xy),但也可以是数值表达式或字符表达式,只在其值为非0,就执行循环体。break语句和continue语句nbreak语句作用:跳出所在的多分支switch语句,跳出所在的while、do-while、for循环语句(提前结束循环ncontinue语句作用:提前结束本次循环体的执行,接着进行下一次循环条件的判别。break语句和continue语句的区别while(表达式1)if(表 达 式 2)continue;while(表达式1)if(表达式2)break;for(r=1;r100)break;printf(%f,aera);raera13.14212.573
12、28.27450.27578.546113.107153.948201.069254.4710314.16几种循环的比较1、四种循环(while、do-while、for、goto)可以互相替换,但应尽量少用goto。2、循环条件:while、do-while在while后面指定;for循环在“表达式2”中指定。3、循环初始条件:while、do-while在循环前指定;for循环在“表达式1”中指定。4、判循环条件的时机:while、for循环先判循环条件,后执行;do-while循环先执行,后判循环条件。5、while、do-while、for循环均可用break语句跳出循环(结束循环),
13、用continue语句提前结束本次循环体的执行。nExample5_6输入一个整数x,判断该数是否是合数质数(素数):只能被1和它本身整除的自然数合数:除了1和它本身外,还存在能整除它的数#include stdio.hmain()int x,i;printf(请输请输入一个整数入一个整数:);scanf(%d,&x);/*查查找范找范围围:2,x-1*/for(i=2;ix;i+)if(x%i=0)/*如果存在一个数能整除如果存在一个数能整除x*/break;/*循循环环提前提前结结束束*/*循循环结环结束有两个可能束有两个可能,一一 ix不成立正常不成立正常结结束束;二二 执执行行brea
14、k以后循以后循环环提前提前结结束束(i肯定小于肯定小于x)*/*如果循如果循环环提前提前结结束束则说则说明明x是个合数是个合数,否否则则 说说明明x是个是个质质数数(素数素数)*/if(ix)printf(%d是个合数是个合数n,x);elseprintf(%d是个是个质质数数(素数素数)n,x);Example5_7输入一个整数,计算该数的因子(不包括自己的因数)之和#includestdio.hmain()intx,i,s;printf(请输入一个整数:);scanf(%d,&x);s=0;/*存储和,初值为0*/for(i=1;ix;i+)/*从1到x-1之间所有的数都逐个进行判断*/i
15、f(x%i=0)/*如果某一个数i是x的因子*/s+=i;/*将i加到s上*/printf(%d的因子之和是%dn,x,s);Example5_8/*输出所有的输出所有的“水仙花数水仙花数”,所谓的所谓的水仙花数水仙花数是指一个三位数是指一个三位数,该数各个位数上的立方和等于它本身该数各个位数上的立方和等于它本身*/*方法方法:穷举法穷举法 列举法列举法 对所有有可能满足条件的数据逐个进行判断对所有有可能满足条件的数据逐个进行判断,找出符合找出符合题目意思的数据题目意思的数据 确定有可能满足条件的范围确定有可能满足条件的范围*/#includestdio.hmain()inti,g,s,b;f
16、or(i=100;i1000;i+)/*对所有的三位数逐个进行判断对所有的三位数逐个进行判断*/*计算出计算出i的个位数的个位数,十位数十位数,百位数百位数*/g=i%10;/*i的个位数的个位数*/s=i/10%10;/*i的十位数的十位数*/b=i/100%10;/*i的百位数的百位数*/*判断判断i与个位数的立方与个位数的立方+十位数的立方十位数的立方+百位数的立方是否相等百位数的立方是否相等*/if(i=g*g*g+s*s*s+b*b*b)printf(%d是个水仙花数是个水仙花数n,i);nExample5_9输出九九乘法表输出九九乘法表#includestdio.hmain()in
17、ti,j;for(i=1;i10;i+)/*总共有总共有9行行,第第i行行*/*第第i行有行有i列列*/for(j=1;j=i;j+)printf(%2d*%d=%-2d,j,i,i*j);printf(n);/*输出换行输出换行*/nExample5_10输入一个输入一个n,输出输出n行行*,其中第其中第几行就有几个图形如下几行就有几个图形如下main()inti,j,n;printf(请输入一个数请输入一个数:);scanf(%d,&n);/*输入一个整数给输入一个整数给n*/*总共输出总共输出n行行*/for(i=1;i=n;i+)/*输出第输出第i行的行的i个个*/for(j=1;j=
18、i;j+)printf(*);/*输出换行输出换行*/printf(n);输入一个输入一个n,输出输出n行行,每行有若干个每行有若干个.和若干个和若干个*,如下图如下图#includestdio.hmain()inti,j,n;printf(请输入一个数请输入一个数:);scanf(%d,&n);/*输入一个整数给输入一个整数给n*/*总共输出总共输出n行行*/for(i=1;i=n;i+)/*输出输出n-i个个.*/for(j=1;j=n-i;j+)printf(.);/*输出第输出第i行的行的2*i-1个个*/for(j=1;j=2*i-1;j+)printf(*);/*输出换行输出换行*
19、/printf(n);n以下程序运行结果是_#includemain()inti=5;doif(i%3=1)if(i%5=2)printf(“*%d”,i);break;i+;while(i!=0);printf(“n”)A)*7B)*3*5C)*5D)*2*6n以下不构成无限循环的语句或语句组是A)n=0;do+n;while(n=0)B)n=0;while(1)n+;C)n=10;while(n);n-;D)for(n=0,i=1;i+)n+=1n以下程序运行结果是_#includemain()inti,j;for(i=3,i=1;i-)for(j=1;j=2;j+)printf(”%d”
20、,i+j);printf(”n”);A)234345B)432543C)233445D)453423n有以下程序运行后的结果是_main()inti,j,x=0;for(i=0;i2;i+)x+;for(j=0;j=3;j+)if(j%2)continue;x+;x+;printf(“x=%dn”,x);A)x=4B)x=8C)x=6 D)x=12n有以下程序运行后的结果是_#includemain()inti;for(i=0;i3;i+)switch(i)case0:printf(“%d”,i);case2:printf(“%d”,i);default:printf(“%d”,i);A)02
21、111B)021021C)000122D)012以下程序的输出结果是_#includemain()intk=0,m=0;inti,j;for(i=0;i2;i+)for(j=0;j3;j+)k+;k-=j;m=i+j;printf(“k=%d,m=%d”,k,m);A)k=0,m=3B)k=0,m=5C)k=1,m=3D)k=1,m=5n以下程序运行后输出的结果是_main()inti,j;for(i=1;i4;i+)for(j=i;j4;j+)printf(“%d*%d=%d”,i,j,i*j);printf(“n”);A)1*1=11*2=21*3=32*1=22*2=43*1=3B)1*1=11*2=21*3=32*2=42*3=63*3=9C)1*1=11*2=22*2=41*3=32*3=63*3=9C)1*1=12*1=22*2=43*1=33*2=63*3=9n若有定义:intk;以下程序的输出结果是_for(k=2;k6;k+,k+)printf(“#%d”,k);n以下程序的输出结果是_#includemain()intn=12345,d;while(n!=0)d=n%10;printf(“%d”,d);n/=10;