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