- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C while循环与for循环
我们在前面已经使用过while与for循环语句。在while循环语句
while (表达式)
语句
中,首先求表达式的值。如果其值非0,则执行语句,并再次求该表达式的值。这一循环过程
一直进行下去,直到该表达式的值为0为止,随后继续执行语句后面的部分。
for 循环语句;
for (表达式1; 表达式2; 表达式3) 语句
它等价于下列while语句: 表达式 1;
while (表达式2) {
语句
表达式 3;
}
但当while 或for 循环语句中包含continue 语句时,上述二者之间就不一定等价了。我
们将在3.7 节中介绍continue语句。
从语法角度看,for 循环语句的3 个组成部分都是表达式。最常见的情况是,表达式1 与表达式3 是赋值表达式或函数调用,表达式2 是关系表达式。这3 个组成部分中的任何部
分都可以省略,但分号必须保留。如果在for 语句中省略表达式1 与表达式3,它就退化成了while 循环语句。如果省略测试条件,即表达式2,则认为其值永远是真值,因此,下列
for循环语句: for (;;) {
...
}
是一个“无限”循环语句,这种语句需要借助其它手段(如break语句或return语句)才能终止执行。
在设计程序时到底选用while循环语句还是for循环语句,主要取决于程序设计人员的个人偏好。例如,在下列语句中:
while ((c = getchar()) == || c == \n || c = \t)
; /* skip white space characters */
因为其中没有初始化或重新初始化的操作,所以使用whi1e循环语句更自然一些。
如果语句中需要执行简单的初始化和变量递增,使用for 语句更合适一些,它将循环控
制语句集中放在循环的开头,结构更紧凑、更清晰。通过下列语句可以很明显地看出这一点:
for (i = 0; i n; i++)
...
这是C 语言处理数组前n 个元素的一种习惯性用法,它类似于Fortran 语言中的DO 循环或Pascal 语言中的for 循环。但是,这种类比并不完全准确,因为在C 语言中,for 循环语句
的循环变量和上限在循环体内可以修改,并且当循环因某种原因终止后循环变量i 的值仍然
保留。因为for语句的各组成部分可以是任何表达式,所以for语句并不限于通过算术级数进行循环控制。尽管如此,牵强地把一些无关的计算放到for 语句的初始化和变量递增部分
是一种不好的程序设计风格,该部分放置循环控制运算更合适。
作为一个较大的例子,我们来重新编写将字符串转换为对应数值的 函数atoi。这里编写
的函数比第2 章中的atoi函数更通用,它可以处理可选的前导空白符以及一个可选的加(+) 或减(-)号。(第4 章将介绍函数atof,它用于对浮点数执行同样的转换。)
下面是程序的结构,从中可以看出输入的格式:
如果有空白符的话,则跳过 如果有符号的话,则读取符号取整数部分,并执行转换
其中的每一步都对输入数据进行相应的处理,并为下一步的执行做好准备。当遇到第一个不能转换为数字的字符时,整个处理过程终止。
#include ctype.h
/* atoi: convert s to integer; version 2 */ int atoi(char s[])
{
int i, n, sign;
for (i = 0; isspace(s[i]); i++) /* skip white space */
;
sign = (s[i] == -) ? -1 : 1;
if (s[i] == + || s[i] == -) /* skip sign */ i++;
for (n = 0; isdigit(s[i]); i++)
n = 10 * n + (s[i] - 0);
return sign * n;
}
标准库中提供了一个更完善的函数strtol,它将字符串转换为长整型数。有关函数strtol 的详细信息,请参见附录B.5节。
把循环控制部分集中在一起,对于多重嵌套循环,优势更为明显。下面的函数是对整型 数组进行排序的Shell排序算法。Shell排序算法是D. L. Shell于1959 年发明的,其基本思想
是:先比较距离远的元素,而不是像简单交换排序算法那样先比较相邻的元素。这样可以快速减少大量的无序情况,从而减轻后续的工作。被比较的元素之间的距离逐步减少,直到减少为1,这时排序变成了相邻元素的互换。
/* shellsort: sort v[0]...v[n-1] into increasing order */ void shellsort(int v[], int n)
您可能关注的文档
最近下载
- 法奥机器人 FR5用户手册V3.3.2.pdf VIP
- 2025-2026学年初中地方、校本课程川教版可爱的四川教学设计合集.docx
- 湖南省武冈市2025届高考化学一模试卷含解析.doc VIP
- 解读《GB_T 44304 - 2024精细陶瓷室温断裂阻力试验方法 压痕(IF)法》.docx VIP
- 小学数学新西师版二年级上册3.7 尺子乐园教学课件(2025秋).pptx VIP
- 100t履带吊安装及拆除施工方案.docx VIP
- 2025年租房合同范本(可直接打印)与租房合同范本(标准版) .pdf VIP
- 物流园区安全管理手册.doc VIP
- 商务英语词汇大全最新完整版本.pdf VIP
- 毕业论文-基于Arduino的智能避障小车设计与实现.doc VIP
文档评论(0)