- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第六章 循环结的程序设计
第六章 循环结构的程序设计
结构化程序由顺序结构、选择结构和循环结构组成。前面已经分别介绍了顺序结构和选择结构的程序设计方法,本章讨论循环结构的程序设计方法。
6.1 循环的基本概念
在第五章的例5-2中曾提到n个数求和有两种方法(以s=1+2+3+……+n为例): ⑴ s=1+2+3+……+n 显然,当n较大时,这种方法不实用。 ⑵ s=0; s=s+1; s=s+2; …… s=s+n; 这种方法需要改造才能达到实用,我们将其改写成(设n=100): s=0; i=1; s=s+i; i=i+1; (s=0+1; i=2) s=s+i; i=i+1; (s=1+2; i=3) …… s=s+i; i=i+1; (s=4950+100; i=101) 将上述过程总结归纳为: s=0; i=1; 当i≤n时,重复执行以下程序段: s=s+i; i=i+1; 可以看到,这种方法有效地克服了第一种方法的缺点,无论n有多大,执行的程序段不变,只是重复执行的次数变化而已。 像这样重复做某件事的现象称为循环。C程序的循环结构就是在满足循环条件时,重复执行某程序段,直到循环条件不满足为止。重复执行的程序段称为循环体。 用已经学过的if语句和goto语句可以设计循环结构程序。
例6-1:计算1+2+3+……+99+100。 #include stdio.h main ( ) { int s,i; s=0; /* 存放累加和的变量初值为0 */ i=1; /* 累加数从1开始 */ k: if (i=100) /* 累加数不超过100 */ { s=s+i; /* 进行累加 */ i=i+1; /* 产生下一个累加数 */ goto k; /* 使程序流程转到if语句,以便继续累加下一个数 */ } printf ( s=1+2+……+100=%d\n, s); } 运行程序: 输出:s=1+2+……+100=5050 存放累加和的变量s的初值为0,其目的是使第一次累加后,s中存放的是第一个累加的数1。然后检测循环控制条件i=100是否满足,若满足,则执行循环体(s=s+i; 和i = i+1;goto k;)。goto语句使程序执行流程转回if语句,以便累加下一个数;if语句则决定是否继续累加。当循环控制条件不满足(即i100)时,退出循环,输出结果。 虽然if和goto语句可以实现循环结构程序,但C语言提供的while语句、do_while语句和for语句才是直接控制循环过程的循环语句。 循环结构有两种形式:当型循环和直到型循环。
1.当型循环 首先判断循环控制表达式是否为真,若为真,则反复执行循环体。若为假,则结束循环。真用Y表示,假用N表示。如图6-1所示。
?
上一页 下一页
6.2 用while语句设计循环结构程序
用while语句可以设计当型循环结构程序。 while语句形式: while ( 表达式 ) 循环体语句 功能:首先计算表达式的值,若为真,则执行循环体语句,执行完毕后,再计算表达式的值,若仍为真,则重复执行循环体语句。直到表达式的值为假时,结束while语句的执行,继续执行while语句后面的语句。while语句构成的循环属于当型循环。如图6-1所示。 说明: ① 表达式是控制循环的条件,它可以是任何类型的表达式。 ② 循环体语句语法上定义为一条语句,若循环体含有多条语句,则必须用大括号把它们括起来,成为复合语句。 ③ while语句的特点是:先判断,后执行。若表达式一开始就为假,则循环一次也不执行。
例6-2:用while语句改写例6-1。执行流程如图6-3所示。 #include stdio.h main ( ) { int s,i; s=0; i=1; while (i=100) { s+=i; i++; } printf (1+2+3+……+100=%d\n, s); } 运行程序: 输出:1+2+3+……+100=5050 与例6-1相比,用while语句更简洁,效率更高。因为while语句是专职循环语句,检测循环控制条件及重复执行循环体的功能集于一身。 注意: ① while语句的循环体中必须出现使循环趋于结束的语句,否则,会出现死循环的现象(即循环永远不会结束)。
文档评论(0)