第10讲 do-while语句 for语句 循环结构的嵌套

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

试将P51例5。1改为do-while语句结构
注意点:P54 do-while语句和while语句的区别在于dowhile是先执行循环体语句,后判断循环条件, 因此do-while至少要执行一次循环体。
用do-while语句改写例5.3的程序
题目:求1+2+3+…+100的值
main() { int i, sum; i=1; sum=0; do { sum= sum+i; i++; 这里一定要 }while(i<=100); 有一个分号 printf("sum=%d\n", sum); } 注意:N_S流程图的直到型循环结构的循环
图5.1 while循环流程图
while(表达式) 循环体语句 例: k=0; while (k<10) {printf(“*”);k++;} 注意:1)表达式不可省;表达式的值为真的时候,作循环; 2)循环体语句,要能改变表达式的值,使其从真变到假;(为 什么啦?)如果循环语句是多条,构成复合语句; 执行过程:P50 P51(1)(2)(3)
f1+f2--->f3 图5-1 for循环运算过程
5.4 for语句和用for语句构成的循环
for语句的一般形式为: for (表达式1;表达式2;表达式3) 循环体语句 for循环语句的执行过程是: (1) 计算”表达式1”的值。 (2) 计算”表达式2”的值; 若其值为非零,转至步骤(3); 若其值为零,则转至步骤(5)。 (3) 执行一次循环体语句。 (4) 计算”表达式3”;然后转向步骤(2),构成循环。 (5) 结束循环,执行for循环之后的语句。
s=1.0; /*s中存放每项分 子,其值按公式在1和-1之间变化*/ while ( fabs(t)>=1e-6) { pi=pi+t;
n+=2.0;
s= -s;
*/
/*改变符号
t=s/n;
} pi=pi*4; printf("pi=%f\n",pi); }
程序执行后输出以下结果:
pi=3.141397
说明:(1)while语句中的表达式可以是任意合法的C表达 式。 (2)如果循环体语句是复合语句,一定要用{ }括起来。 (3) 在循环体语句中应该包含能够使循环趋于结束的 操作,以避免出现死循环。
例5.1 编程求1+2+3+…+100的值。
这是一个求100个数的累加和问题。所加的 加数从1变化到100,因此我们可以在循环体中 设计一个整型变量i,使它的初值为1,每循环 一次使i的值增1,一直循环到i的值超过100为 止,用这个办法就解决所需的加数问题。 要解决求累加和的问题,还要再设计一个变 量sum用来存放这100个数的和值,先求0+1的和 并将其放在sum中,然后把sum中的数加上2再存 放在sum中,依次类推。 在这里,sum累加的过程要放在循环体中, 由计算机来判断所加的数是否已经超过100。
条件的描述方法与C语言的do-while语句的 循环条件的测试方法稍有不同。
P54例5。4 该数列变化的规律: 除第一、二项外,后面的各项值为前面两项之和; 位置号:1 2 3 4 5 6 7 数列: 1 1 2 3 5 8 13 f1+f2--->f3 f1+f2--->f3
f1+f2--->f3
main( ) {float r, s ,pi=3.1416; for(r=0.5; r<=2.5; r+=0.5 ) {s=pi*r*r ; printf("r=%3.1fs=%f\n", r, s); } } 试改为:非常规for 结构
5.5 循环结构的嵌套
在一个循环语句的循环体内又完整地包含了另一 个循环语句,称为循环嵌套。循环嵌套的书写采用 缩进形式.
例5.4 编程计算多个圆的面积
本例要求计算5个不同半径的圆面积, 且半径值的变化是有规律的,从0.5mm 开始按增 mm的规律递增,可直接用半径r 作为for语句的循环控制变量,每循环一 次使r的值增0.5 ,直到r大于2.5为止。
变量r具有双 重功能,它既 是循环控制变 量,又是圆的 半径值,它的 值由0.5变化到 2.5,循环体共 执行5次,当r 增到3.0时,条 件表达式 r<=2.5的值为 0,从而退出循 环。
小组讨论: 2、P53 迭代法
5.3 用do-while语句构成的循环
由do-while语句构成的循环称 为”直到型”循环,do-while语句 的一般形式为: do 循环体语句 while(表达式);
do-while语句的执行过程是:先执行循环体语句, 再求表达式的值,若表达式的值为“真”(非0 数值)则再执行循环体语句,由此构成循环,直 到表达式的值为“假” (数值0)时结束循环。 如图所示。
第十讲
while语句、do-while语句、for 语句 循环结构的嵌 套
5.1 while循环语句
由while语句构成的循环也称”当”循 环。 while循环的一般形式如下: while(表达式) 循环体语句
图5.1 while循环流程图
while语句的执行过程是: 先计算while表达式的值,当表达式的值为非零时, 便执行循环体语句,之后再计算该表达式的值,由此 构成循环,直到有一次求得表达式的值为零时才结束 循环,并继续执行循环体语句之外的后续语句。
小组讨论:
1、程序5-3:求输入的某个数是否为素数。若是, 输出YES,若不是,输出NO。
素数是指那些大于1,且除了1和它本身以外不能被其 他任何数整除的数。如2、3、5、7、11、……都是素数; 4、6、8、9、……则不是素数。 为了判断某数x是否为素数,最简单的方法是用2、3、 4、…x-1,这些数逐个去除x,看能否除尽,只要能被其 中某一个数除尽,x就不是素数;否则,若不能被任何一 个数除尽,x就是素数。
for语句的常规使用方法: “表达式1”用来给循环变量赋初值或做一些初始 工作; “表达式2”用来作为判断循环是否结束的条件; “表达式3”用来修改循环变量的值,使得循环能 够趋于结束。
例如:
for(k=0; k<10; k++) printf("*");
以上for循环在一行上输出Leabharlann Baidu0个“*”号。
实际上只要试除到,就已经可以说明x是否为素数了。 这是因为如果小于等于的数都不能除尽x,则大于的数也 不可能除尽x。试除到,可以减少循环次数,提高程序的 运行效率。 程序代码如下: #include "math.h" main( )
{
int
i, x, yes, a;
printf("Enter integer number : "); scanf ("%d",&x);
main() /*程序4 */ for语句的非常规使用方法2 { int i=1, sum=0; 三个表达式都被省掉了! 分隔符“ ;”不能省。 for ( ; ; ) {sum= sum + i++ ; 由于没有了表达式2, if i>100 goto pend; 用goto语句结束循环。 } pend: printf(“sum=%d\n”, sum); }
程序5-2:用π/4=1-1/3+1/5-1/7+1/9 -…公式 求π的近似值,直到最后一项的绝对值小于10-6为止。
本题的基本算法也是求累加和,但比例5-1稍为复杂。 与例5-1比较,不同的是: (1)用分母来控制循环次数,若用n存放分母的值, 则每累加一次n应当增2,每次累加的数不是整数,而是 一个实数,因此n应当定义成float类型。 (2)可以看成隔一项的加数是负数,若用t来表示相 加的每一项,因此,每加一项之后,t的符号应当改变, 这可用交替乘1和-1来实现。
例5.5 循环嵌套的应用--输出九九乘法表。
在编写程序时,循环嵌套的书写要采用缩进形 式,如在例5.5的程序中,内循环中的语句应该比 外循环中的语句有规律地向右缩进2~4列。 main ( ) {int i, j; for(i=1; i<=9; i++) { for(j=1; j<= i; j++) printf("%1d*%1d =%2d ", i, j , i*j); printf("\n"); } }
例5.3程序,求1+2+3+…+100的值
main() { int i, sum; i=1; sum=0; while(i<=100) {sum= sum + i ; i++; } printf("sum=%d\n", sum); } 程序运行后的输出结果: sum=5050
思考:P51例5.1 sum=sum+i*i sum<1000 自己试写出该程序
i++ ;
当x=2时,因i的初值2大于a,while循环根本不执行,yes仍保 持为1,输出的素数2;当x>2时,进入循环,若x为素数, yes的值不变,仍为1,若x能被2~的某个数整除,则x不是素 数,使yes的值变为0,并且立即退出循环。退出循环后,if的 语句判断yes的值为1时,输出YES,否则输出NO。
3)从以上求π的公式来看,不能决定n的最终值应该是多少; 但可以用最后一项t(1/n)的绝对值小于10-6来作为循环的 结束条件。 程序如下:
#include "math.h" 包含 math.h文件*/
main( )
/*调用fabs函数时要求
{
int
s;
float n, t, pi; t=1.0; 值,初值为1 */ pi=0; pi中存放所求的π的值,初值为0*/ n=1.0; 每项分母*/ /*t中存放每项的 /* /*n中存放
for语句的常规使用方法例 P 56例5.5
“表达式1”是逗号表达式 main() /*程序1 */ 做一些初始工作,准备累加! 给循环变量赋初值 { int i, sum; 判断循环是否结束! for (i=1,sum=0; i<=100; i++) sum= sum + i ; printf("sum=%d\n", sum); 使得循环能够趋于结束。 }
yes=1; i=2; a=(int)sqrt ( (double) x); while( yes && i<=a) { } printf("%d ",x); if ( yes ) else } printf("YES\n"); printf("NO\n"); if(x%i== 0) yes=0;
for语句的非常规使用方法
从语法上来讲,三个表达式都可以是任意合法的C表达式, 各表达式之间用”;”隔开,并且这三个表达式都是任选项。 例如:我们可以用for循环语句将例5.3的程序改写为如下几 种形式,它们都能正确地求出1+2+3+…+100的值。
main() /*程序3 */ main() /*程序2 */ 表达式1和表达式3都省掉了! { int i=1, sum=0; 表达式1省略了! { int i=1, sum=0; for ( (; ; i<=100; ) i++) for i<=100; 循环体语句是复合语 {sum= sum + i; ; sum= sum + i 句,花括号不能省! i++ ; printf(“sum=%d\n”, sum); } } printf(“sum=%d\n”, sum); }
main() /*程序5 */ 循环体语句是一个空语句! { int i, sum=0; for (i=1; i<=100 ; sum=sum+i++ ); printf(“sum=%d\n”, sum); }
注意在循环体语句之前不能有分号
main() main() { sum=0; { int i, int i, sum=0; for i<=100; i++) ; for (i=1 ; (i=1 ; i<=100; i++) ; sum= ; sum= sum + isum + i ; printf("sum=%d\n", printf("sum=%d\n", sum);sum); /*前面两个程序的执行过程,结果 } } =101*/ main() { int i, sum=0; for (i=1 ; i<=100; i++); sum= sum + i ; printf("sum=%d\n", sum); 即:循环体语句是一个空语句! }
相关文档
最新文档