《C语言程序设计与数据结构》课件第05章.ppt





《《C语言程序设计与数据结构》课件第05章.ppt》由会员分享,可在线阅读,更多相关《《C语言程序设计与数据结构》课件第05章.ppt(21页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第五章循环结构学习重点:学习重点:l掌握while语句及for语句的执行流程;l学会white语句及for语句的灵活运用。C语言程序设计与数据结构 循环结构,是程序设计三种基本结构之一。其特点是,在给定条件成立时,反复执行某程序段,直到条件不成立为止。给定的条件称为循环条件,反复执行的程序段称为循环体。利用循环结构进行程序设计,一方面降低了问题的复杂性,减少了程序设计的难度:另一方面也充分发挥了计算机自动执行、运算速度快的特点。C语言提供了多种循环语句:(1)while语句;(2)do-while语句(3)for语句。上述多种循环语句,可以组成各种不同形式的循环结构。在程序设计时应根据实际需要
2、,合理地选择实现循环的语句。C语言程序设计与数据结构5.1 while语句 while语句用来实现“当型”循环结构。一般形式为:while(表达式)语句体其中,while后面用圆括号括起来的表达式是循环条件,通常是可以判断真假的条件表达式,用来控制循环体是否执行。后面的语句称为循环体,可以是单条语句或多条语句,若有多条语句,则需要用花括号括起来构成复合语句。while语句的具体执行过程:如图5.1所示。(1)先计算表达式的值。当值非0时,执行步骤(2);当值为0时,执行骤(4)。(2)执行循环体中语句。(3)转去执行步骤(1)。(4)退出while循环。由上所述,“当型”循环结构的特点是:先判
3、断表达式,后执行语句。语句A表达式0(假)1(真)C语言程序设计与数据结构【例5.1】用while语句求1+2+3+4+99+100的和。#includemain()inti,sum=0;i=1;while(i100时,循环条件为假,循环结束。如果没有这一语句,则i的值始终不变,循环将无限地进行下去。(4)语句的先后位置可根据需要进行调整,变量的初值也不是一成不变的。例如,上述程序可进行如下改编:i=0;while(i100)i+;sum=sum+i;C语言程序设计与数据结构【例5.2】统计从键盘输入一行字符中大写字母的个数。#includemain()intcount=0;charc;pri
4、ntf(inputastring:n);while(c=getchar()!=n)if(c=A&c=Z)count+;printf(%d,count);上述程序中的循环条件为getchar()!=n,其含义是,只要从键盘输入的字符不是回车就继续循环,直到按回车键停止。循环体中嵌套if单分支语句,coun+完成对输入的大写字母的个数计数。C语言程序设计与数据结构通过以上两个例子我们可以看出,使用通过以上两个例子我们可以看出,使用while语句应注意以下几点:语句应注意以下几点:(1)while语句中的表达式一般是关系表达式或逻辑表达式,只要表达式的值为真(非0)即可继续循环,执行循环体中的语句。
5、因此说,如果表达式的值一开始就为“假”,则循环体将一次也不执行。(2)循环体中若包括有一个以上的多条语句时,则必须用括起来,组成复合语句。如果不加,while语句的范围只到while后面的第一个分号处。(3)避免出现死循环现象。循环体中一定要有使循环趋向结束的语句;若循环条件的值永远为真,而循环体中又没有其他中止循环的语句,该循环将无休止地进行下去,形成死循环。C语言程序设计与数据结构5.2 do-while语句 do-while语句用来实现“直到型”循环结构。一般形式为:do语句体while(表达式);/*注意最后有个分号*/这个循环与while循环的不同在于:它先执行循环中的语句,然后再判
6、断表达式是否为真,如果为真则继续循环;如果为假,则终止循环执行。因此,do-while循环至少要执行一次循环体中的语句。do-while语句的具体执行过程如图5.2所示:语句表达式0(假)非0(真)C语言程序设计与数据结构【例5.3】用do-while语句求1+2+3+4+99+100的和。#includemain()inti,sum=0;i=1;dosum=sum+i;i+;while(i=100);printf(sum=%dn,sum);和while语句一样,用do-while语句编程时,应注意对循环控制变量进行值的修改。当循环体包含一个以上多条语句时,应用括起来组成复合语句。do-whi
7、le语句是以do开始,以while条件后的分号结束的。由由do-while构成的循环与构成的循环与while循环的重要区别是:循环的重要区别是:while循环的控制出现在循环体之前,只有当while后面表达式的值为真时,才执行循环体;在do-while构成的循环体中,总是先执行一次循环体,然后判断循环条件是否成立。因此说,在do-while构成的循环中无论循环条件是否成立,循环体都将会至少执行一次。C语言程序设计与数据结构【例5.4】while和do-while循环的比较:求1+2+3+n的和,n的值从键盘上输入。main()main()inti=1,s=0,n;inti=0,s=0,n;sc
8、anf(%d,n);scanf(“%d”,&n);while(i=n)dos+=i;s+=i;i+;i+;while(i=10);printf(sum=dn,s);printf(“sum=%dn”,s);程序运行如下:程序运行如下:101sum=55sum=55-1-1sum=0s=-1从上述例题可以看出:对于同一个问题,可以用while处理,也可以用do-while来处理。这两种结果是可以互相转换的。在一般情况下,用while语句和do-while语句处理同一问题时,若二者的循环体部分一样,它们的结果也是一样。但当while语句的条件(表达式)一开始就不成立(为假)时,两种循环的结果是不同的
9、。C语言程序设计与数据结构5.3 for 语句 for语句是C语言所提供的功能更强、使用更广泛、且最为灵活的一种循环语句,它不仅可以用在循环次数已知的情况,也可以用于循环次数不确定而只给出循环结束条件的情况。5.3.1 for语句的一般形式语句的一般形式一般形式为:for(表达式1;表达式2;表达3)语句其中,“for是C语言的关键字,其后的一对圆括号中通常含有三个表达式,各表达式之间用“;”隔开,这三个表达式可以是任意形式的表达式,通常主要用于for循环的控制。紧跟在for()之后的循环体,可以是一条语句或多条语句;若是多条语句,则应该用大括号括起来组成复合语句。C语言程序设计与数据结构5.
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- C语言程序设计与数据结构 语言程序设计 数据结构 课件 05

限制150内