c语言课件第6章循环

PPT
  • 阅读 78 次
  • 下载 0 次
  • 页数 53 页
  • 大小 429.582 KB
  • 2022-11-24 上传
  • 收藏
  • 违规举报
  • © 版权认领
下载文档30.00 元 加入VIP免费下载
此文档由【小橙橙】提供上传,收益归文档提供者,本网站只提供存储服务。若此文档侵犯了您的版权,欢迎进行违规举报版权认领
c语言课件第6章循环
可在后台配置第一页与第二页中间广告代码
c语言课件第6章循环
可在后台配置第二页与第三页中间广告代码
c语言课件第6章循环
可在后台配置第三页与第四页中间广告代码
c语言课件第6章循环
c语言课件第6章循环
还剩10页未读,继续阅读
【这是免费文档,您可以免费阅读】
/ 53
  • 收藏
  • 违规举报
  • © 版权认领
下载文档30.00 元 加入VIP免费下载
文本内容

【文档说明】c语言课件第6章循环.ppt,共(53)页,429.582 KB,由小橙橙上传

转载请保留链接:https://www.ichengzhen.cn/view-44587.html

以下为本文档部分文字说明:

第六章本章要点循环的基本概念不同形式的循环控制多重循环问题主要内容6.1概述6.2goto语句以及用goto语句构成循环6.3用while语句实现循环6.4用do-while语句实现循环6.5用for语句实现循环6.6循环的嵌套6.7几种循环的比较6.8bre

ak语句continue和语句6.9程序举例C程序设计(第三版)http://ccf.tsinghua.edu.cn46.1概述什么是循环?为什么要使用循环?1001nyn问题1:问题2:求学生平均成绩分数相加后除以课数在许多问题中需要用到循

环控制。循环结构是结构化程序设计的基本结构之一,它和顺序结构、选择结构共同作为各种复杂程序的基本构造单元。C程序设计(第三版)http://ccf.tsinghua.edu.cn56.2goto语句以及用goto语句构成循环•goto语句

——无条件转向语句goto语句标号;•语句标号用标识符表示,它的定名规则与变量名相同,即由字母、数字和下划线组成,其第一个字符必须为字母或下划线。例如:gotolabel_1;合法;goto123;不合法.C程序设计(第三

版)http://ccf.tsinghua.edu.cn66.2goto语句以及用goto语句构成循环结构化程序设计方法主张限制使用goto语句,因为滥用goto语句将使程序流程无规律、可读性差。一般来说,可以有两种用

途:(1)与if语句一起构成循环结构;(2)从循环体中跳转到循环体外。但是这种用法不符合结构化原则,一般不宜采用,只有在不得已时(例如能大大提高效率)才使用。C程序设计(第三版)http://ccf.tsinghua.edu.cn7例6.1用if语句和goto语句构成循

环,求1到100的和voidmain(){inti,sum=0;i=1;loop:if(i<=100){sum=sum+i;i++;gotoloop;}printf("%d\\n″,sum);}1001nn说明:这里用的是“当型”循环结构,当满足“i<=100”时执行花括弧

内的循环体。运行结果:5050C程序设计(第三版)http://ccf.tsinghua.edu.cn86.3用while语句实现循环while语句用来实现“当型”循环结构。一般形式:while(表达式)语句

当表达式为非0值时,执行while语句中的内嵌语句。其特点是:先判断表达式,后执行语句。C程序设计(第三版)http://ccf.tsinghua.edu.cn9例6.2求1到100的和#include<stdio.h>voidmain()

{inti,sum=0;i=1;while(i<=100){sum=sum+i;i++;}printf(″%d\n″,sum);}1001nn说明:(1)循环体如果包含一个以上的语句,应该用花括弧括起来,以复合

语句形式出现.(2)在循环体中应有使循环趋向于结束的语句。运行结果:5050C程序设计(第三版)http://ccf.tsinghua.edu.cn106.3用while语句实现循环注意:(1)循环体如果包含一个以上的语

句,应该用花括弧括起来,以复合语句形式出现。(2)在循环体中应有使循环趋向于结束的语句。如果无此语句,则i的值始终不改变,循环永不结束。C程序设计(第三版)http://ccf.tsinghua.edu.cn116.4用do-whil

e语句实现循环do-while语句的特点:先执行循环体,然后判断循环条件是否成立。一般形式:do循环体语句while(表达式);执行过程:先执行一次指定的循环体语句,然后判别表达式,当表达式的值为非零(“真”)时,返回重新执行循环体语句,如此

反复,直到表达式的值等于0为止,此时循环结束。C程序设计(第三版)http://ccf.tsinghua.edu.cn12例6.3求1到100的和#include<stdio.h>voidmain(){inti

,sum=0;i=1;do{sum=sum+i;i++;}while(i<=100);printf("%d\n″,sum);}运行结果:50501001nnC程序设计(第三版)http://ccf.tsinghua.edu

.cn136.4用do-while语句实现循环while语句和用do-while语句的比较:在一般情况下,用while语句和用do-while语句处理同一问题时,若二者的循环体部分是一样的,它们的结果也一样。但是如果while后面的表达式一开始就为假(0值)时,两种循环的

结果是不同的。C程序设计(第三版)http://ccf.tsinghua.edu.cn14例6.4while和do-while循环的比较(1)#include<stdio.h>(2)#include<stdi

o.h>voidmain()voidmain(){intsum=0,i;{intsum=0,i;scanf(“%d″,&i);scanf(”%d″,&i);while(i<=10)do{sum=sum+I;{sum=sum+i;i++;i++;}while(i<=10);

printf(“sum=%d\n″,sum);}printf(“sum=%d\n”,sum);}1001nn运行结果:1↙sum=55再运行一次:11↙sum=0运行结果:1↙sum=55再运行一次:11↙sum=11说明:(1)当while后面的表达式的第

一次的值为“真”时,两种循环得到的结果相同。否则,二者结果不相同。C程序设计(第三版)http://ccf.tsinghua.edu.cn156.5用for语句实现循环•C语言中的for语句使用最为灵活,不仅可以用于循环次数已

经确定的情况,而且可以用于循环次数不确定而只给出循环结束条件的情况,它完全可以代替while语句。•一般形式:for(表达式1;表达式2;表达式3)语句C程序设计(第三版)http://ccf.tsinghua.edu.cn166.5用for语句实现循环for

语句的执行过程:(1)先求解表达式1。(2)求解表达式2,若其值为真(值为非0),则执行for语句中指定的内嵌语句,然后执行下面第(3)步。若为假(值为0),则结束循环,转到第(5)步。(3)求解表达式3。(4)转回上面第(2)步骤继续执行。(5)循环结束,执

行for语句下面的一个语句C程序设计(第三版)http://ccf.tsinghua.edu.cn176.5用for语句实现循环表达式2?执行语句成立不成立执行for循环之后的语句执行表达式3执行表达式1循环初始条件循环控制条件循环体

•for语句等价于下列语句:表达式1;while(表达式2){语句;表达式3;}C程序设计(第三版)http://ccf.tsinghua.edu.cn186.5用for语句实现循环for语句最简单的

形式:for(循环变量赋初值;循环条件;循环变量增值)例如:for(i=1;i<=100;i++)sum=sum+i;相当于:i=1;while(i<=100){sum=sum+i;i++;}用for语句简单、方便。C程序设计(第三版)http://ccf.tsinghua.e

du.cn196.5用for语句实现循环说明:(1)for语句的一般形式中的“表达式1”可以省略,此时应在for语句之前给循环变量赋初值。注意省略表达式1时,其后的分号不能省略。如for(;i<=100;i++)sum=sum+i

;执行时,跳过“求解表达式1”这一步,其他不变。C程序设计(第三版)http://ccf.tsinghua.edu.cn206.5用for语句实现循环说明:(2)如果表达式2省略,即不判断循环条件,循环无终止地进

行下去。也就是认为表达式2始终为真。例如:for(i=1;;i++)sum=sum+i;表达式1是一个赋值表达式,表达式2空缺。它相当于:i=1;while(1){sum=sum+1;i++;}C程序设计(第三版)http://ccf.tsinghua.edu.cn2

16.5用for语句实现循环说明:(3)表达式3也可以省略,但此时程序设计者应另外设法保证循环能正常结束。如:for(i=1;i<=100;){sum=sum+i;i++;}在上面的for语句中只有表达式1和表达式2,而没有表达式3。i++的操作不放在f

or语句的表达式3的位置处,而作为循环体的一部分,效果是一样的,都能使循环正常结束。C程序设计(第三版)http://ccf.tsinghua.edu.cn226.5用for语句实现循环说明:(4)可以省略表达式1和表达式

3,只有表达式2,即只给循环条件。如:for(;i<=100;)while(i<=100){sum=sum+i;相当于{sum=sum+i;i++;}i++;}在这种情况下,完全等同于while语句。可见for语句比while语句功能强,除了可以给出循环条件外,还可以赋初值,使循

环变量自动增值等。C程序设计(第三版)http://ccf.tsinghua.edu.cn236.5用for语句实现循环说明:(5)3个表达式都可省略,如:for(;;)语句相当于while(1)语句即不设初值,不判断条件(认为表达式2为真值),循环变量不增值。无终止地执行循环体。C程序设计

(第三版)http://ccf.tsinghua.edu.cn246.5用for语句实现循环说明:(6)表达式1可以是设置循环变量初值的赋值表达式,也可以是与循环变量无关的其他表达式。如:for(sum=0;i<=10

0;i++)sum=sum+i;表达式3也可以是与循环控制无关的任意表达式。C程序设计(第三版)http://ccf.tsinghua.edu.cn256.5用for语句实现循环说明:表达式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

都是逗号表达式,各包含两个赋值表达式,即同时设两个初值,使两个变量增值.C程序设计(第三版)http://ccf.tsinghua.edu.cn266.5用for语句实现循环说明:在逗号表达式内按自左至右顺序求解,整个逗号表达式的值为其中最右边的表达式的值。如:fo

r(i=1;i<=100;i++,i++)sum=sum+i;相当于for(i=1;i<=100;i=i+2)sum=sum+i;C程序设计(第三版)http://ccf.tsinghua.edu.cn276.5用for语句实现循环

说明:(7)表达式一般是关系表达式(如i<=100)或逻辑表达式(如a<b&&x<y),但也可以是数值表达式或字符表达式,只要其值为非零,就执行循环体。C程序设计(第三版)http://ccf.tsinghua.edu.cn28

6.5用for语句实现循环说明:①for(i=0;(c=getchar())!=′\n′;i+=c);在表达式2中先从终端接收一个字符赋给c,然后判断此赋值表达式的值是否不等于′\n′(换行符),如果不等于′\n′

,就执行循环体。注意:此for语句的循环体为空语句,把本来要在循环体内处理的内容放在表达式3中,作用是一样的。可见for语句功能强,可以在表达式中完成本来应在循环体内完成的操作。C程序设计(第三版)http://ccf.tsinghu

a.edu.cn296.5用for语句实现循环说明:②for(;(c=getchar())!=′\n′;)printf(″%c″,c);for语句中只有表达式2,而无表达式1和表达式3。其作用是每读入一个字符后立即输出该字符,直到输入一个“换行”为止。请注意,从终端键盘向计算机输入时,是在按

Enter键以后才将一批数据一起送到内存缓冲区中去的。运行情况:Computer↙(输入)Computer(输出)而不是CcoommppuutteerrC程序设计(第三版)http://ccf.tsing

hua.edu.cn306.5用for语句实现循环注意:C语言中的for语句比其他语言(如BASIC,PASCAL)中的FOR语句功能强得多。可以把循环体和一些与循环控制无关的操作也作为表达式1或表达式3出现,这样程序可以短小简洁。

但过分地利用这一特点会使for语句显得杂乱,可读性降低,最好不要把与循环控制无关的内容放到for语句中。C程序设计(第三版)http://ccf.tsinghua.edu.cn316.6循环的嵌套•一个循环体内又包含另一个完整的循环结构称为循环的嵌套。内嵌的循环中还

可以嵌套循环,这就是多层循环。•三种循环(while循环、do-while循环和for循环)可以互相嵌套。C程序设计(第三版)http://ccf.tsinghua.edu.cn326.6循环的嵌套•下面几种都是合

法的形式:(1)while()(2)do(3)for(;;){…{…{while()dofor(;;){…}{…}{…}}while();}}while();C程序设计(第三版)http://ccf.tsinghua.edu.cn336.6循环的嵌套(4)while()(5)for(;;

)(6)do{…{…{…do{…}while()for(;;){}while(){}…{…}…}}}while()C程序设计(第三版)http://ccf.tsinghua.edu.cn346.7几种循环的比较(

1)四种循环都可以用来处理同一问题,一般情况下它们可以互相代替。但一般不提倡用goto型循环。(2)在while循环和do-while循环中,只在while后面的括号内指定循环条件,因此为了使循环能正常结束,应在循环体中包含使循环趋于结束的语句(如i++,或i=i+1等)。C程序设计(第三版

)http://ccf.tsinghua.edu.cn356.7几种循环的比较for循环可以在表达式3中包含使循环趋于结束的操作,甚至可以将循环体中的操作全部放到表达式3中。因此for语句的功能更强,凡用while循环能完成的,用for循环都能实现。(3)用while和do-while循环时,循

环变量初始化的操作应在while和do-while语句之前完成。而for语句可以在表达式1中实现循环变量的初始化。C程序设计(第三版)http://ccf.tsinghua.edu.cn366.7几种循环的比较(4)whi

le循环、do-while循环和for循环,可以用break语句跳出循环,用continue语句结束本次循环(break语句和continue语句见下节)。而对用goto语句和if语句构成的循环,不能用break语句和continue语句进行控制。C程序设计(第三版)http://

ccf.tsinghua.edu.cn376.8break语句和continue语句6.8.1break语句break语句可以用来从循环体内跳出循环体,即提前结束循环,接着执行循环下面的语句一般形式:break;注意:break语句不能用于循环语句和switch语句之外的任何其他语句中。C程

序设计(第三版)http://ccf.tsinghua.edu.cn386.8break语句和continue语句例:floatpi=3.14159;for(r=1;r<=10;r++){area=pi*r*r;if(ar

ea>100)break;printf(″r=%f,area=%f\n″,r,area);}程序的作用是计算r=1到r=10时的圆面积,直到面积area大于100为止。从上面的for循环可以看到:当area>100时,执行break语句,提前结束循环,即

不再继续执行其余的几次循环。C程序设计(第三版)http://ccf.tsinghua.edu.cn396.8break语句和continue语句6.8.2continue语句作用为结束本次循环,即跳过循环体中下面尚未执行的语句,接着进行下一次是否执行循环的判定.一般形式:continu

e;C程序设计(第三版)http://ccf.tsinghua.edu.cn406.8break语句和continue语句continue语句和break语句的区别continue语句只结束本次循环,而不是终止整个循环的执行。while(表达式1)for{…if(表达式2)continue;…

}0C程序设计(第三版)http://ccf.tsinghua.edu.cn416.8break语句和continue语句continue和break的区别break语句则是结束整个循环过程,不再判断执行循环的条件是否成立

。while(表达式1)for{…if(表达式2)break;…}C程序设计(第三版)http://ccf.tsinghua.edu.cn42例6.5把100~200之间的不能被3整除的数输出。#include<stdio.h>voidmain()

{intn;for(n=100;n<=200;n++){if(n%3==0)continue;printf("%d″,n);}}1001nn说明:当n能被3整除时,执行continue语句,结束本次循环(即跳过printf函数语句),只有n不能被3整除时才执行printf函数。C程序设

计(第三版)http://ccf.tsinghua.edu.cn436.9程序举例例6.6用π/4≈1-1/3+1/5-1/7+…公式求π的近似值,直到某一项的绝对值小于为止。N-S图表示算法C程序设计(第三版)http://ccf.tsing

hua.edu.cn44例6.6求pi的近似值#include<stdio.h>#include<math.h>voidmain(){ints;floatn,t,pi;t=1;pi=0;n=1.0;s=1;whi

le(fabs(t)>1e-6){pi=pi+t;n=n+2;s=-s;t=s/n;}pi=pi*4;printf(″pi=%10.6f\n″,pi);}1001nn运行结果:pi=3.141594C程序设计(第三版)http://ccf

.tsinghua.edu.cn456.9程序举例例6.7求Fibonacci数列前40个数。这个数列有如下特点:第1,2两个数为1,1。从第3个数开始,该数是其前面两个数之和。即:•F(1)=1(n=1)•F(2)=1(n=2)•F(n)=F(n-1)

+F(n-2)(n≥3)算法如图所示:1FC程序设计(第三版)http://ccf.tsinghua.edu.cn46例6.7求Fibonacci数列前40个数。#include<stdio.h>voidma

in(){longintf1,f2;inti;f1=1;f2=1;for(i=1;i<=20;i++){printf(″%12ld%12ld″,f1,f2);if(i%2==0)printf(″\n″);f1=f1+f2;f2=f

2+f1;}}1001nn运行结果:112358132134558914423337761098715972584418167651094617711286574636875025121393196418317811514229832040134626

92178309352457857022887922746514930352241578173908816963245986102334155C程序设计(第三版)http://ccf.tsinghua.edu.cn476.9程序举例例6.8判断m是否素数。算法思想:

让m被2到除,如果m能被2~之中任何一个整数整除,则提前结束循环,此时i必然小于或等于k(即);如果m不能被2~k(即)之间的任一整数整除,则在完成最后一次循环后,i还要加1,因此i=k+1,然后才终止循环。在循环之后判别i的值是否大于或等于k+1,若是,则表明未曾被2~k之间任一

整数整除过,因此输出“是素数”。1FC程序设计(第三版)http://ccf.tsinghua.edu.cn481FC程序设计(第三版)http://ccf.tsinghua.edu.cn49例6.8判断m是否素数。#include<stdio.h>#include<math.h>voi

dmain(){intm,i,k;scanf(″%d″,&m);k=sqrt(m);for(i=2;i<=k;i++)if(m%i==0)break;if(i>k)printf("%disaprimenumber\n″,m);

elseprintf("%disnotaprimenumber\n″,m);}1001nn运行结果:17↙17isaprimenumberC程序设计(第三版)http://ccf.tsinghua.edu.cn50例6.9求100~20

0间的全部素数。#include<stdio.h>#include<math.h>voidmain(){intm,k,i,n=0;for(m=101;m<=200;m=m+2){k=sqrt(m);for(i=2;i<=k;i++

)if(m%i==0)break;if(i>=k+1){printf("%d″,m);n=n+1;}if(n%10==0)printf(″\n″);}printf("\n");}1001nn运行结

果:101103107109113127131137139149151157163167173179181191193197199C程序设计(第三版)http://ccf.tsinghua.edu.cn516.9程序举例例6.10译密码。为使电文保密,往往按一定规律将其转换成密

码,收报人再按约定的规律将其译回原文。思路:可以按以下规律将电文变成密码:将字母A变成字母E,a变成e,即变成其后的第4个字母,W变成A,X变成B,Y变成C,Z变成D。1FC程序设计(第三版)http://ccf.tsinghua.edu.cn52

例6.10输入一行字符,要求输出其相应的密码include<stdio.h>voidmain(){charc;while((c=getchar())!=′\n′){if((c>=′a′&&c<=′z′)||(c>=

′A′&&c<=′Z′)){c=c+4;if(c>′Z′&&c<=′Z′+4||c>′z′)c=c-26;}printf(″%c\n″,c);}}1001nn•运行结果:China!↙Glmre!C程序设计(第三版)http://cc

f.tsinghua.edu.cn531F

小橙橙
小橙橙
文档分享,欢迎浏览!
  • 文档 4039
  • 被下载 8
  • 被收藏 0
相关资源
广告代码123
若发现您的权益受到侵害,请立即联系客服,我们会尽快为您处理。侵权客服QQ:395972555 (支持时间:9:00-21:00) 公众号
Powered by 太赞文库
×
确认删除?