第6章 循环体结构
※知识点总结※
一.
1.循环类型:①计数控制的循环
②条件控制的循环
③标记控制的循环
2.循环语句:①while
②do-while
③for
④循环嵌套
3.流程的转移控制:①goto
②break
③continue
二.while语句
一般形式:while(表达式)
{
循环体语句
}
⑴while语句是条件循环语句,大多数情况下用于解决不确定循环次数的问题——即只有当某条件成立时,循环才会结束,否则循环将一直继续循环下去。while语句也可用于解决确定循环次数的问题。使用while语句时,条件表达式的设置比较关键,表达式的正确与否决定了循环次数是否正确、循环是否能正常结束,从而避免程序进入死循环。
⑵while语句还有一个特殊的用途是设计无限循环的程序,在一些特定的场合,循环需要无限期地执行下去,知道循环被强行退出。
▲PS:(1)while语句的语法与if语句类似,要使用缩进来分割子句。
(2)while语句的条件表达式不需要用括号括起来,表达式后面必须有冒号。
(3)python与其他大多数语言不同,在while循环中可以使用else语句,即构成了while-else语句循环结构。
三.do-while语句
一般形式: do{
循环体语句
}while(表达式);
▲PS:这个while后面的小括号必须接;
1.循环过程:
(1)先执行循环体,执行完毕跳转到2
(2)判断表达式的结果是否为真,如果为真,跳转到1,否则跳转到3。
(3)跳出循环
2.do-while和while最大的区别:
do-while至少能执行1次循环体,但是while可能一次都不执行。
四.for语句
一般形式:for(表达式1;表达式2;表达式3)
{
循环体语句
}
☆在C语言中,for语句使用最为灵活,它完全可以取代 while 语句。它的一般形式为:
for(表达式1;表达式2;表达式3) 语句
㈠它的执行过程如下:
- 先求解表达式1。
- 求解表达式2,若其值为真(非0),则执行for语句中指定的内嵌语句,然后执行下面第3)步;若其值为假(0),则结束循环,转到第5)步。
- 求解表达式3。
- 转回上面第2)步继续执行。
- 循环结束,执行for语句下面的一个语句。
㈡for语句最简单的应用形式也是最容易理解的形式如下:
for(循环变量赋初值;循环条件;循环变量增量) 语句
循环变量赋初值总是一个赋值语句, 它用来给循环控制变量赋初值; 循环条件是一个关系表达式,它决定什么时候退出循环;循环变量增量,定义循环控制变量每循环一次后 按什么方式变化。这三个部分之间用“;”分开。
例如:
for(i=1; i<=100; i++)sum=sum+i;
先给i赋初值1,判断i是否小于等于100, 若是则执行语句,之后值增加1。再重新判断, 直到条件为假,即i>100时,结束循环。
相当于:
i=1;
while(i<=100)
{
sum=sum+i;
i++;
}
对于for循环中语句的一般形式,就是如下的while循环形式:
表达式1;
while(表达式2)
{
语句
表达式3;
}
▲PS: - for循环中的“表达式1(循环变量赋初值)”、“表达式2(循环条件)”和“表达式3(循环变量增量)”都是选择项, 即可以缺省,但“;”不能缺省。
- 省略了“表达式1(循环变量赋初值)”, 表示不对循环控制变量赋初值。
- 省略了“表达式2(循环条件)”, 则不做其它处理时便成为死循环。
例如:
for(i=1;;i++)sum=sum+i;
相当于:
i=1;
while(1)
{
sum=sum+i;
i++;
} - 省略了“表达式3(循环变量增量)”, 则不对循环控制变量进行操作,这时可在语句体中加入修改循环控制变量的语句。
例如:
for(i=1;i<=100;)
{
sum=sum+i;
i++;
} - 省略了“表达式1(循环变量赋初值)”和“表达式3(循环变量增量)”。
例如:
for(;i<=100;)
{
sum=sum+i;
i++;
}
相当于:
while(i<=100)
{
sum=sum+i;
i++;
} - 3个表达式都可以省略。
例如:
for(;;)语句
相当于:
while(1)语句 - 表达式1可以是设置循环变量的初值的赋值表达式,也可以是其他表达式。
例如:
for(sum=0;i<=100;i++)sum=sum+i; - 表达式1和表达式3可以是一个简单表达式也可以是逗号表达式。
for(sum=0,i=1;i<=100;i++)sum=sum+i;
或:
for(i=0,j=100;i<=100;i++,j–)k=i+j; - 表达式2一般是关系表达式或逻辑表达式,但也可是数值表达式或字符表达式,只要其值非零,就执行循环体。
例如:
for(i=0;(c=getchar())!=’\n’;i+=c);
又如:
for(;(c=getchar())!=’\n’?
printf(“%c”,c);
五.goto语句
goto语句是一种无条件转移语句
使用格式:
goto 语句标号(标识符)
这个标识符加上一个:一起出现在程序中某处,执行goto语句后,程序会跳转到标号处并执行其后的语句
六.break语句
break语句通常用在循环语句和开关语句中。当break用于开关语句switch中时,可使程序跳出switch而执行switch以后的语句;如果没有break语句,则将成为一个死循环而无法退出。
当break语句用于do-while、for、while循环语句中时,可使程序终止循环而执行循环后面的语句, 通常break语句总是与if语句联在一起。即满足条件时便跳出循环。
▲PS: - break语句对if-else的条件语句不起作用。
- 在多层循环中, 一个break语句只向外跳一层。
七. continue 语句
continue语句的作用是跳过循环本中剩余的语句而强行执行下一次循环。continue语句只用在for、while、do-while等循环体中,常与if条件语句一起使用,用来加速循环。
※应用※
(1)用while语句级数求和
级数求和问题解决的关键是:观察表达式中的相邻两项,找出规律,将规律转化为若干通式。为了将复杂问题简单化,通项将每一项的分子、分母、符号、求和等通式分开处理,这样做的好处是利于查找问题。
(2)数据处理问题
①累加和问题
②连乘积问题
●例题
○请输出1000以内的所有素数
例程:
int main(int argc,char *argv[])
{
int i,j;
int num = 0;
for(j = 2;j <= 1000;j++)
{
for(i = 2; i <= j/2;i++)
{
if(j % i == 0)
break;
}
if(i == (j/2 + 1))
{
printf("%d\t",j);
num++;
if(num % 10 == 0)
putchar(’\n’);
}
}
return 0;
}
○ 求1-100 的和
例程:分别使用while与do while
int main(int argc,char argv[])
{
int sum = 0;
int i = 1;
/
while(i <= 100)
{
sum += i;
i++;
}
*/
do
{
sum +=i++;
}while(i < 101);
printf(“sum = %d\n”,sum);
return 0;
}
○输出100以内的不能被3整除的数
例程:
int main(int argc,char argv[])
{
int i;
for(i = 1;i <= 100;i++)
{
/
if(i % 3 != 0)
printf("%d\t",i);
*/
if(i % 3 == 0)
continue;
printf("%d\t",i);
}
return 0;
}
※感悟※
循环结构是程序中一种很重要的结构。其特点是,在给定条件成立时,反复执行某程序段,直到条件不成立为止。给定的条件称为循环条件,反复执行的程序段称为循环体。C语言提供了多种循环语句,可以组成各种不同形式的循环结构。
- 用goto语句和if语句构成循环;
- 用while语句;
- 用do-while语句;
- 用for语句;