C语言程序设计第5章-循环结构程序设计ppt课件

上传人:资****亨 文档编号:145849578 上传时间:2020-09-23 格式:PPT 页数:42 大小:263KB
返回 下载 相关 举报
C语言程序设计第5章-循环结构程序设计ppt课件_第1页
第1页 / 共42页
C语言程序设计第5章-循环结构程序设计ppt课件_第2页
第2页 / 共42页
C语言程序设计第5章-循环结构程序设计ppt课件_第3页
第3页 / 共42页
C语言程序设计第5章-循环结构程序设计ppt课件_第4页
第4页 / 共42页
C语言程序设计第5章-循环结构程序设计ppt课件_第5页
第5页 / 共42页
点击查看更多>>
资源描述

《C语言程序设计第5章-循环结构程序设计ppt课件》由会员分享,可在线阅读,更多相关《C语言程序设计第5章-循环结构程序设计ppt课件(42页珍藏版)》请在金锄头文库上搜索。

1、.,目录,5.1循环结构程序设计的概述 5.2用while语句实现循环结构程序设计 5.3用do-while语句实现循环结构程序设计 5.4用for语句实现循环结构程序设计 5.5循环的嵌套 5.6 几种循环语句的比较 5.7 用break和continue语句提前结束循环 5.8循环结构程序设计举例,.,5.1循环结构程序设计概述,1.实现循环的三种语句 C语言提供了多种循环语句,可以组成各种不同形式的循环结构。 1)用for语句:属于先判断后执行的当型循环结构; 2)用while语句:属于先判断后执行的当型循环结构;可以解决任何循环结构的问题,但代码比用for语句多; 3)用do-whil

2、e语句:先执行后判断的当型结构,循环体至少被执行一次,比使用while语句先判断后执行结构少判断一次,执行效率提高。,.,5.1循环结构程序设计概述,2.循环结构程序的四个组成部分 1)循环初始化部分:为循环做准备; 2)循环控制部分:控制循环是否进行; 3)循环体部分:重复循环的主体; 4)循环修改部分:为下次循环做准备。,.,5.2 用while语句实现循环结构程序设计,1.While语句的格式 while(表达式) 语句; 或写成: while(表达式)语句; 其中表达式是循环条件,语句为循环体。 2.while语句的功能 计算表达式的值,当值为真(非0)时,则重复执行循 环体语句,直到

3、表达式值为假时结束循环。当第一次 判断表达式的值就为假时,则循环体语句一次也不被 执行。,.,5.2 用while语句实现循环结构程序设计,2.While语句的功能,.,5.2 用while语句实现循环结构程序设计,【例5_1】用while语句求p=n!,.,5.2 用while语句实现循环结构程序设计,【例5_1】用while语句求p=n! #include int main() int i=1,p=1; /循环初始化部分 while(i=5) /循环控制部分 p=p*i; /循环体语句 i+; /循环修改部分 printf(5!=%dn,p); return 0; ,.,5.2 用whil

4、e语句实现循环结构程序设计,【例5_2】用while语句求,.,5.2 用while语句实现循环结构程序设计,【例5_2】用while语句求 #include int main() int i=1,sum=0; /循环初始化部分 while(i=100) /循环控制部分 sum=sum+i; /循环体语句 i+; /循环修改部分 printf(%dn,sum); return 0; ,.,5.2 用while语句实现循环结构程序设计,【例5_3】给一个正整数n(n2),用while循环结构判断它是否素数。 分析:循环进行的条件是:ik和flag=0。因为在ik时,显然不必再去检查n是否能被整除

5、,此外如果flag=1,就表示n已被某一个数整除过,肯定是非素数无疑,也不必再检查了。只有ik和flag=0两者同时满足才需要继续检查。循环体只有一个判断操作:判断n能否被i整除,如不能,则执行i=i+1,即i的值加1,以便为下一次判断作准备。如果在本次循环中n能被i整除,则令flag=1,表示n已被确定为非素数了,这样就不再进行下一次的循环了。如果n不能被任何一个i整除,则flag始终保持为0。因此,在结束循环后根据flag的值为0或1,分别输出n是素数或非素数的信息。,.,5.2 用while语句实现循环结构程序设计,#include #include void main() int n,

6、k,i,flag; printf(请输入n:); scanf(“%d”, ,.,5.2 用while语句实现循环结构程序设计,3.使用while语句注意事项 1)while语句中的表达式通常是逻辑表达式或关系表达式,但也可以是其它表达式,甚至也可以是一个变量或是一个常量,只要表达式的值为真,即可继续循环。 【例5_4】while语句中的表达式是算术表达式的情况。 #include void main() int a=0,n; printf(n input n:); scanf(%d, ,.,5.2 用while语句实现循环结构程序设计,2)循环体如包括有一个以上的语句,则必须用括起来,组成复合

7、语句。 【例5_7】给出两个正整数,求它们的最大公约数。 求最大公约数可以用辗转相除法,也称欧几里德法。 分析:以大数a作被除数,小的数b作为除数,相除后余数为r。如果r0,则将b=a,r=b,再进行一次相除,得到新的r。如果r仍不等于0,则重复上面过程,直到r=0为止。此时的b就是最大公约数。,.,5.2 用while语句实现循环结构程序设计,#include void main() int a,b,t,r; printf(请输入a:); scanf(%d, ,.,5.3 用do-while语句实现循环结构程序设计,do-while语句可以实现循环体至少被执行一次的循环。 1.do-whil

8、e语句格式 do 语句; while(表达式); 或写成: do 语句; while(表达式); 2.do-while语句功能 先执行循环体语句,然后再判断表达式是否为真,如果 为真,则继续循环;如果为假,则终止循环。因此, do-while循环至少要执行一次循环语句。,.,5.3 用do-while语句实现循环结构程序设计,2.do-while语句功能,.,5.3 用do-while语句实现循环结构程序设计,【例5_6】求 ,直到前后两项之差小于10-3为止(后一项不累加)。 分析:n是某一项的分母,例如第3项的n是3。term在开始时是多项式第1项的值,先把它加到s中。然后n 的值加,te

9、rm的值变成1/2,此时它代表第二项。如果此两项之差大于或等于10-3,则再执行循环体,把term 值赋给term1.然后再累加到s中去。可以看出:程序中term1代表当前要累加的项,term代表下一项,如果这两项之差未超过10-3,就将下一项加到s 中。,.,5.3 用do-while语句实现循环结构程序设计,#include void main() float s=0,term,term1; int n=1; term = 1 / n; do term1 = term; s = s + term1; n = n + 1; term = 1 / n; while(term1-term = 1

10、0-3); printf(“%f”,s); ,.,5.3 用do-while语句实现循环结构程序设计,3.while和do-while循环比较 while和do- while结构都为当型循环结构,都是当条件成立时执行循环体;不同的是,前者为先判断,循环体执行次数大于或等于0;后者为后判断,循环体执行次数大于或等于1。 【例5_7】while和do-while循环比较。 1)while循环 #include void main() int sum=0,i; printf(输入i:); scanf(%d, ,.,5.3 用do-while语句实现循环结构程序设计,2)do-while循环 #inc

11、lude void main() int sum=0,i; printf(输入i:); scanf(%d, ,.,5.4 用for语句实现循环结构程序设计,1.for语句格式 for(表达式1;表达式2;表达式3)语句; 或写成: for(表达式1;表达式2;表达式3) 语句; 2.for语句功能 它的执行过程如下: 1)先求解表达式1。 2)求解表达式2,若其值为真(非0),则执行for语句中指定的内嵌语句,然后执行下面第3步;若其值为假(0),则结束循环,转到第5步。 3)求解表达式3。 4)转回上面第2步继续执行。 5)循环结束,执行for语句下面的一个语句。,.,5.4 用for语句实

12、现循环结构程序设计,3.for语句应用形式 for语句最简单的应用形式也是最容易理解的形式如下: for(循环变量赋初值;循环控制条件;循环变量增量)语句; 循环变量赋初值总是一个赋值语句,它用来给循环控制变量赋初值;循环控制条件是一个关系表达式,它决定什么时候退出循环;循环变量增量,定义循环控制变量每循环一次后按什么方式变化。这三个部分之间用分号隔开。 例如:for(i=a;ib时,结束循环。,.,5.4 用for语句实现循环结构程序设计,4.for语句转换为while语句 在C语言中,for语句使用最为灵活,它完全可以取代while语句。对于for循环中语句的一般形式,可以用如下的whil

13、e循环形式替代: 表达式1; while(表达式2) 语句; 表达式3; ,.,5.4 用for语句实现循环结构程序设计,5.for语句使用注意事项 1)for循环中的表达式1(循环变量赋初值)、表达式2(循环条件)和表达式3(循环变量增量)都是可选项,即可以缺省,但分号不能缺省。 2)表达式1可以是设置循环变量初值的赋值表达式,也可以是其他表达式。 3)表达式1和表达式3可以是简单表达式也可以是逗号表达式。 4)表达式2一般是关系表达式或逻辑表达式,但也可是数值表达式或常量、变量,只要其值非零,就执行循环体。,.,5.4 用for语句实现循环结构程序设计,6. for语句使用举例 【例5_8

14、】用for语句求 s=1+2+3+100 #include void main() int s=0,i; for(i=1;i=100;i+) s=s+i; printf(“%dn”,s); ,.,5.4 用for语句实现循环结构程序设计,【例5_9】用for语句求n的阶乘。 #include void main() int i,n,p=1; printf(“输入n:”); scanf(“%d”, ,.,5.4 用for语句实现循环结构程序设计,【例5_10】猴子吃桃问题。这也是一个有趣的数学问题。 小猴子第一天摘下若干个桃子,当即吃掉一半,还不过瘾,又多吃了一个。第二天早上又将剩下的桃子吃掉一

15、半,又多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。到第10天早上猴子想再吃时,见到只剩下一个桃子了。问第一天猴子共摘了多少个桃子。 这是一个递推问题,先从最后一天的桃子推出倒数第二天的桃子,再从倒数第二天的桃子推出倒数第三天的桃子,但它属于倒推,即从最后的结果倒推出原始的状况。 设第n天桃子数为xn,已知它是前一天的桃子数x n-1的1/2再减去1。即xn= xn-1/2-1 或 xn-1=(xn+1)2 利用此公式可以从第n天的桃子数推出前一天的桃子数。递推的初始条件为:x10=1,.,5.4 用for语句实现循环结构程序设计,#include void main() int x=

16、1,n; for(n=9;n=1;n-) x=(x+1)*2; printf(The number of peaches is:%dn,x); ,.,5.5 循环嵌套,在一个循环体内又完整地包含另一个循环,称为循环的嵌套。几种类型的循环可以互相嵌套。例如可以在一个for循环中包含一个do循环,也可以在一个while循环中包含一个for循环。内外循环之间不得交叉。 当程序中有控制结构的互相嵌套时,其执行流程仍严格按照每个控制结构既定的流程进行。,.,5.5 循环嵌套,【例5_11】打印出乘法九九表。九九表是一个9行9列的二维表,行和列都要变化,而且在变化中互相约束。 #include void main() int i,j; for(i=1;i=9;i+) for(j=1;j=i;j+) printf(%3d ,i*j); printf(n

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 高等教育 > 大学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号