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

上传人:cl****1 文档编号:584056477 上传时间:2024-08-30 格式:PPT 页数:49 大小:1.52MB
返回 下载 相关 举报
C言语课件-第5章 循环结构程序设计_第1页
第1页 / 共49页
C言语课件-第5章 循环结构程序设计_第2页
第2页 / 共49页
C言语课件-第5章 循环结构程序设计_第3页
第3页 / 共49页
C言语课件-第5章 循环结构程序设计_第4页
第4页 / 共49页
C言语课件-第5章 循环结构程序设计_第5页
第5页 / 共49页
点击查看更多>>
资源描述

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

1、第第5章章 循环循环结构程序设计结构程序设计本章要点本章要点5.1 概述概述5.2 goto语句以及用语句以及用goto语句构成循环语句构成循环5.3 用用while语句实现循环语句实现循环5.4 用用do-while语句实现循环语句实现循环5.5 用用for 语句实现循环语句实现循环 5.6 循环的嵌套循环的嵌套5.7 几种循环的比较几种循环的比较5.8 break语句语句continue和语句和语句5.9 程程 序序 举举 例例主要内容主要内容5.1 概述概述什么是循环?什么是循环?为什么要使用循环?为什么要使用循环?问题问题1 1:问题问题2:2:求学生平均成绩求学生平均成绩 分数相加后

2、除以课数分数相加后除以课数 在许多问题中需要用到循环控制。循环结构是结构在许多问题中需要用到循环控制。循环结构是结构化程序设计的基本结构之一,它和顺序结构、选择化程序设计的基本结构之一,它和顺序结构、选择结构共同作为各种复杂程序的基本构造单元。结构共同作为各种复杂程序的基本构造单元。5.2 goto语句及用语句及用goto语句构成循环语句构成循环gotogoto语句为无条件转向语句,它的一般形式为语句为无条件转向语句,它的一般形式为 gotogoto 语句标号;语句标号;语句标号用标识符表示,它的定名规则与变量名相语句标号用标识符表示,它的定名规则与变量名相同,即由字母、数字和下划线组成,其第

3、一个字符同,即由字母、数字和下划线组成,其第一个字符必须为字母或下划线。必须为字母或下划线。 例如:例如:gotogoto label_1; label_1; 合法合法; ; gotogoto 123 123; 不合法不合法. .5.2 goto语句及用语句及用goto语句构成循环语句构成循环 结构化程序设计方法主张限制使用结构化程序设计方法主张限制使用gotogoto语句,因为语句,因为滥用滥用gotogoto语句将使程序流程无规律、可读性差。语句将使程序流程无规律、可读性差。一般来说,可以有两种用途:一般来说,可以有两种用途:(1 1)与)与ifif语句一起构成循环结构;语句一起构成循环结

4、构;(2 2)从循环体中跳转到循环体外。)从循环体中跳转到循环体外。 但是这种用法不符合结构化原则,一般不宜采用,但是这种用法不符合结构化原则,一般不宜采用,只有在不得已时只有在不得已时( (例如能大大提高效率例如能大大提高效率) )才使用。才使用。5.2 goto语句及用语句及用goto语句构成循环语句构成循环例例5.1 用用if语句和语句和goto语句构成循环,求语句构成循环,求1到到100的和的和void main( ) int i, sum=0; i=1; loop:if(i=100) sum=sum+i; i+; goto loop; printf(%dn”,sum); 说明:说明:

5、这里用的是这里用的是“当型当型”循循环环结构,当满足结构,当满足“i=100” 时时执执行花括弧内的循环体。行花括弧内的循环体。 运行结果:运行结果:5050while语句用来句用来实现“当型当型”循循环结构。构。一般形式:一般形式: while (表达式表达式) 语句句 当表达式当表达式为非非0值(即(即为真)真)时,执行行while语句句中的内嵌中的内嵌语句。句。 其特点是:先判断表达式,后其特点是:先判断表达式,后执行行语句。句。5.3 用用while语句实现循环语句实现循环5.3 用用while语句实现循环语句实现循环例例5.2 求求1到到100的和的和#include void ma

6、in() int i,sum=0; i=1; while (i=100) sum=sum+i; i+; printf(“%dn”,sum); 说明:说明:(1)循环体如果包含一个以上)循环体如果包含一个以上的语句,应该用花括弧括起的语句,应该用花括弧括起来,以复合语句形式出现;来,以复合语句形式出现;(2)在循环体中应有使循环趋)在循环体中应有使循环趋向于结束的语句。向于结束的语句。 运行结果:运行结果:50505.3 用用while语句实现循环语句实现循环注意:注意:(1 1)循环体如果包含一个以上的语句,应该用花括)循环体如果包含一个以上的语句,应该用花括弧括起来,以复合语句形式出现。弧括

7、起来,以复合语句形式出现。 (2 2)在循环体中应有使循环趋向于结束的语句。如)在循环体中应有使循环趋向于结束的语句。如果无此语句,则果无此语句,则i i的值始终不改变,循环永不结的值始终不改变,循环永不结束。束。死循环死循环5.4 用用do-while语句实现循环语句实现循环do-whiledo-while语句的特点语句的特点: :先执行循环体,然后判断循环先执行循环体,然后判断循环条件是否成立。条件是否成立。一般形式一般形式: : do do 循环体语句循环体语句 while while ( (表达式表达式) );执行过程:执行过程: 先执行一次指定的循环体语句,然后判别表达式,先执行一次

8、指定的循环体语句,然后判别表达式,当表达式的值为非零当表达式的值为非零(“(“真真”) ) 时,返回重新执时,返回重新执行循环体语句,如此反复,直到表达式的值等于行循环体语句,如此反复,直到表达式的值等于0 0(即假)为止,此时循环结束。(即假)为止,此时循环结束。5.4 用用do-while语句实现循环语句实现循环例例5.3 求求1到到100的和的和#include void main() int i,sum=0; i=1; do sum=sum+i; i+; while(i=100); printf(%dn”,sum);运行结果:运行结果:50505.4 用用do-while语句实现循环语

9、句实现循环whilewhile语句和用语句和用do-whiledo-while语句的比较语句的比较: :在一般情况下,用在一般情况下,用whilewhile语句和用语句和用do-whiledo-while语句处理同语句处理同一问题时,若二者的循环体部分是一样的,它们的结一问题时,若二者的循环体部分是一样的,它们的结果也一样。但是如果果也一样。但是如果whilewhile后面的表达式一开始就为假后面的表达式一开始就为假(0 0值)时,两种循环的结果是不同的。值)时,两种循环的结果是不同的。whilewhile语句执语句执行行0 0次循环体,次循环体,do-whiledo-while语句至少执行一

10、次循环体。语句至少执行一次循环体。5.4 用用do-while语句实现循环语句实现循环例例5.4 while和和do-while循环的比较循环的比较 (1) (2)#include #include void main( ) void main( ) int sum=0,i; int sum=0,i; scanf(“%d”,&i); scanf(”%d”,&i); while (i=10) do sum=sum+I; sum=sum+i; i+; i+; while (i=10); printf(“sum=%dn”, printf(“sum=%dn”, sum); sum ); 运行结果:运行

11、结果:1 sum=55 再运行一次:再运行一次: 11 sum=0运行结果:运行结果:1 sum=55 再运行一次:再运行一次: 11 sum=11说明:说明:当当whilewhile后面的表达式的第后面的表达式的第一次的值为一次的值为“真真”时,两种循环得时,两种循环得到的结果相同。否则,二者结果不到的结果相同。否则,二者结果不相同。相同。5.5 用用for 语句实现循环语句实现循环C C语言中的语言中的forfor语句使用最为灵活,不仅可以用于循语句使用最为灵活,不仅可以用于循环次数已经确定的情况,而且可以用于循环次数不环次数已经确定的情况,而且可以用于循环次数不确定而只给出循环结束条件的

12、情况,它完全可以代确定而只给出循环结束条件的情况,它完全可以代替替whilewhile语句。语句。一般形式一般形式: : forfor( (表达式表达式1;1;表达式表达式2;2;表达式表达式3) 3) 语句语句5.5 用用for 语句实现循环语句实现循环forfor语句的执行过程:语句的执行过程:(1 1)先求解表达式)先求解表达式1 1。(2 2)求解表达式)求解表达式2 2,若其值为真(值为非,若其值为真(值为非0 0),则),则 执行执行forfor语句中指定的内嵌语句,然后执行语句中指定的内嵌语句,然后执行 下面第(下面第(3 3)步。若为假(值为)步。若为假(值为0 0),则结束)

13、,则结束 循环,转到第(循环,转到第(5 5)步。)步。(3 3)求解表达式)求解表达式3 3。(4 4)转回上面第()转回上面第(2 2)步骤继续执行。)步骤继续执行。(5 5)循环结束,执行)循环结束,执行forfor语句下面的一个语句。语句下面的一个语句。5.5 用用for 语句实现循环语句实现循环表达式表达式2?执行语句执行语句成立成立不成立不成立执行执行for循环之后的语循环之后的语句句执行表达式执行表达式3执行表达式执行表达式1循环初始条件循环初始条件循环控制条件循环控制条件循环体循环体for语句等价于下列语句:语句等价于下列语句:表达式表达式1;while (表达式表达式2) 语

14、句语句; 表达式表达式3; 5.5 用用for 语句实现循环语句实现循环forfor语句最简单的应用形式也就是最易理解的形式如下:语句最简单的应用形式也就是最易理解的形式如下: forfor( (循环变量赋初值循环变量赋初值; ;循环条件循环条件; ;循环变量增值循环变量增值) ) 例如例如: : for(ifor(i=1;i=100;i+) sum=1;i=100;i+) sum=sum+isum+i; ;它相当于以下语句:它相当于以下语句: i=1;i=1; while(iwhile(i=100)=100) sum= sum=sum+i;isum+i;i+;+; 显然,用显然,用for语句

15、简单、语句简单、方便。方便。 5.5 用用for 语句实现循环语句实现循环说明:说明:(1 1)forfor语句的一般形式中的语句的一般形式中的“表达式表达式1 1”可以省略,可以省略,此时应在此时应在forfor语句之前给循环变量赋初值。注意省语句之前给循环变量赋初值。注意省略表达式略表达式1 1时,其后的分号不能省略。如时,其后的分号不能省略。如 for(;i=100;i+) sum=sum+i; 执行时,跳过执行时,跳过“求解表达式求解表达式1 1”这一步,其他不变。这一步,其他不变。5.5 用用for 语句实现循环语句实现循环说明:说明:(2 2)如果表达式)如果表达式2 2省略,即不

16、判断循环条件,循环无省略,即不判断循环条件,循环无终止地进行下去。也就是认为表达式终止地进行下去。也就是认为表达式2 2始终为真。始终为真。例如:例如:for(i=1; ;i+) sum=sum+i; 表达式表达式1 1是一个赋值表达式,表达式是一个赋值表达式,表达式2 2空缺。它相当于:空缺。它相当于: i=1; while(1) sum=sum+1;i+; 5.5 用用for 语句实现循环语句实现循环说明:说明:(3 3)表达式)表达式3 3也可以省略,但此时程序设计者应另外也可以省略,但此时程序设计者应另外设法保证循环能正常结束。如:设法保证循环能正常结束。如: for(i=1;i=10

17、0;) sum=sum+i; i+; 在上面的在上面的forfor语句中只有表达式语句中只有表达式1 1和表达式和表达式2 2,而没,而没有表达式有表达式3 3。i+i+的操作不放在的操作不放在forfor语句的表达式语句的表达式3 3的的位置处,而作为循环体的一部分,效果是一样的,位置处,而作为循环体的一部分,效果是一样的,都能使循环正常结束。都能使循环正常结束。 5.5 用用for 语句实现循环语句实现循环说明:说明:(4 4)可以省略表达式)可以省略表达式1 1和表达式和表达式3 3,只有表达式,只有表达式2 2,即,即只给循环条件。如:只给循环条件。如: for(;i=100;) wh

18、ile(i=100) sum=sum+i; 相当于相当于 sum=sum+i; i+; i+; 在这种情况下,完全等同于在这种情况下,完全等同于whilewhile语句。可见语句。可见forfor语句语句比比whilewhile语句功能强,除了可以给出循环条件外,还语句功能强,除了可以给出循环条件外,还可以赋初值,使循环变量自动增值等。可以赋初值,使循环变量自动增值等。5.5 用用for 语句实现循环语句实现循环说明:说明:(5 5)3 3个表达式都可省略,如:个表达式都可省略,如: for(; ;) for(; ;) 语句语句 相当于相当于 while(1) while(1) 语句语句即不设

19、初值,不判断条件(认为表达式即不设初值,不判断条件(认为表达式2 2为真值),为真值),循环变量不增值。无终止地执行循环体。循环变量不增值。无终止地执行循环体。 5.5 用用for 语句实现循环语句实现循环说明:说明:(6 6)表达式)表达式1 1可以是设置循环变量初值的赋值表达式,可以是设置循环变量初值的赋值表达式,也可以是与循环变量无关的其他表达式。如也可以是与循环变量无关的其他表达式。如: : for (sum=0;i=100;i+) sum=sum+i;表达式表达式3 3也可以是与循环控制无关的任意表达式。也可以是与循环控制无关的任意表达式。 5.5 用用for 语句实现循环语句实现循

20、环说明:说明:表达式表达式1 1和表达式和表达式3 3可以是一个简单的表达式,也可以可以是一个简单的表达式,也可以是逗号表达式,即包含一个以上的简单表达式,中间是逗号表达式,即包含一个以上的简单表达式,中间用逗号间隔。如:用逗号间隔。如: for(sum=0,i=1;i=100;i+) sum=sum+i;或或 for(i=0,j=100;i=j;i+,j-) k=i+j;表达式表达式1 1和表达式和表达式3 3都是逗号表达式,各包含两个赋值都是逗号表达式,各包含两个赋值表达式,即同时设两个初值,使两个变量增值。表达式,即同时设两个初值,使两个变量增值。5.5 用用for 语句实现循环语句实现

21、循环说明:说明:在逗号表达式内按自左至右顺序求解,整个逗号表达在逗号表达式内按自左至右顺序求解,整个逗号表达式的值为其中最右边的表达式的值。如式的值为其中最右边的表达式的值。如: : for(i=1;i=100;i+,i+) sum=sum+i;相当于相当于 for(i=1;i=100;i=i+2) sum=sum+i; 5.5 用用for 语句实现循环语句实现循环说明:说明:(7 7)表达式一般是关系表达式)表达式一般是关系表达式( (如如i=100)i=100)或逻辑表或逻辑表达式(如达式(如ab & xyab & xy),但也可以是数值表达式或),但也可以是数值表达式或字符表达式,只要其

22、值为非零,就执行循环体。字符表达式,只要其值为非零,就执行循环体。5.5 用用for 语句实现循环语句实现循环说明:说明: for(i=0;(c=getchar()!=n;i+=c); 在表达式在表达式2 2中先从终端接收一个字符赋给中先从终端接收一个字符赋给c c,然后判,然后判断此赋值表达式的值是否不等于断此赋值表达式的值是否不等于nn(换行符),(换行符),如果不等于如果不等于nn,就执行循环体。,就执行循环体。注意:注意: 此此forfor语句的循环体为空语句,把本来要在循环体语句的循环体为空语句,把本来要在循环体内处理的内容放在表达式内处理的内容放在表达式3 3中,作用是一样的。可见

23、中,作用是一样的。可见forfor语句功能强,可以在表达式中完成本来应在循环语句功能强,可以在表达式中完成本来应在循环体内完成的操作。体内完成的操作。5.5 用用for 语句实现循环语句实现循环说明:说明: for( ;(c=for( ;(c=getchargetchar()!=n;)()!=n;) printf(%cprintf(%c,c);c); for for语句中只有表达式语句中只有表达式2 2,而无表达式,而无表达式1 1和表达式和表达式3 3。 其作用是每读入一个字符后立即输出该字符,直到其作用是每读入一个字符后立即输出该字符,直到输入一个输入一个“换行换行”为止。请注意,从终端键

24、盘向计为止。请注意,从终端键盘向计算机输入时,是在按算机输入时,是在按EnterEnter键以后才将一批数据一键以后才将一批数据一起送到内存缓冲区中去的。起送到内存缓冲区中去的。运行情况:运行情况:Computer (输入输入)Computer (输出输出)而不是而不是Ccoommppuutteerr5.5 用用for 语句实现循环语句实现循环注意注意: : C C语言中的语言中的forfor语句比其他语言(如语句比其他语言(如BASICBASIC,PASCALPASCAL)中的)中的FORFOR语句功能强得多。可以把循环体和语句功能强得多。可以把循环体和一些与循环控制无关的操作也作为表达式一

25、些与循环控制无关的操作也作为表达式1 1或表达式或表达式3 3出现,这样程序可以短小简洁。但过分地利用这一出现,这样程序可以短小简洁。但过分地利用这一特点会使特点会使forfor语句显得杂乱,可读性降低,最好不要语句显得杂乱,可读性降低,最好不要把与循环控制无关的内容放到把与循环控制无关的内容放到forfor语句中。语句中。5.6 循环的嵌套循环的嵌套一个循环体内又包含另一个完整的循环结构称为循一个循环体内又包含另一个完整的循环结构称为循环的嵌套。内嵌的循环中还可以嵌套循环,这就是环的嵌套。内嵌的循环中还可以嵌套循环,这就是多层循环。多层循环。三种循环(三种循环(whilewhile循环、循环

26、、do-whiledo-while循环和循环和forfor循环)循环)可以互相嵌套。可以互相嵌套。5.6 循环的嵌套循环的嵌套下面几种都是合法的形式:下面几种都是合法的形式: (1) (2) (3) while( ) do for(;) while( ) do for(;) while( ); while( ); 5.6 循环的嵌套循环的嵌套 (4) (5) (6) while( ) for(;) do do while( ) for(;) while( ) while( ) 5.7 几种循环的比较几种循环的比较(1 1)四种循环都可以用来处理同一问题,一般情况下)四种循环都可以用来处理同一问

27、题,一般情况下它们可以互相代替。但一般不提倡用它们可以互相代替。但一般不提倡用gotogoto型循环。型循环。(2 2)在)在whilewhile循环和循环和do-whiledo-while循环中,只在循环中,只在whilewhile后面后面的括号内指定循环条件,因此为了使循环能正常结的括号内指定循环条件,因此为了使循环能正常结束,应在循环体中包含使循环趋于结束的语句束,应在循环体中包含使循环趋于结束的语句( (如如i+i+,或,或i=i+1i=i+1等等) )。 for for循环可以在表达式循环可以在表达式3 3中包含使循环趋于结束的操中包含使循环趋于结束的操作,甚至可以将循环体中的操作全

28、部放到表达式作,甚至可以将循环体中的操作全部放到表达式3 3中。中。因此因此forfor语句的功能更强,凡用语句的功能更强,凡用whilewhile循环能完成的,循环能完成的,用用forfor循环都能实现。循环都能实现。5.7 几种循环的比较几种循环的比较(3 3)用)用whilewhile和和do-whiledo-while循环时,循环变量初始化的循环时,循环变量初始化的操作应在操作应在whilewhile和和do-whiledo-while语句之前完成。而语句之前完成。而forfor语语句可以在表达式句可以在表达式1 1中实现循环变量的初始化。中实现循环变量的初始化。(4 4)whilew

29、hile循环、循环、do-whiledo-while循环和循环和forfor循环,可以用循环,可以用breakbreak语句跳出循环,用语句跳出循环,用continuecontinue语句结束本次循环语句结束本次循环(breakbreak语句和语句和continuecontinue语句见下节)。而对用语句见下节)。而对用gotogoto语句和语句和ifif语句构成的循环,不能用语句构成的循环,不能用breakbreak语句和语句和continuecontinue语句进行控制。语句进行控制。5.8 break语句和语句和continue语句语句 breakbreak语句语句 breakbreak

30、语句可以用来从循环体内跳出循环体,即提前语句可以用来从循环体内跳出循环体,即提前结束循环,接着执行循环下面的语句结束循环,接着执行循环下面的语句 一般形式:一般形式: break;break;注意:注意: breakbreak语句不能用于循环语句和语句不能用于循环语句和switchswitch语句之外的任语句之外的任何其他语句中。何其他语句中。 5.8 break语句和语句和continue语句语句 例:例:float pi=3.14159;for(r=1;r100) break; printf(r=%f,area=%fn,r,area); 程序的作用是计算程序的作用是计算r=1r=1到到r=

31、10r=10时的圆面积,直到时的圆面积,直到面积面积areaarea大于大于100100为止。从上面的为止。从上面的forfor循环可以看循环可以看到:当到:当area100area100时,执行时,执行breakbreak语句,提前结束语句,提前结束循环,即不再继续执行其余的几次循环循环,即不再继续执行其余的几次循环。5.8 break语句和语句和continue语句语句 continuecontinue语句语句 作用为结束本次循环,即跳过循环体中下面尚未执作用为结束本次循环,即跳过循环体中下面尚未执行的语句,接着进行下一次是否执行循环的判定行的语句,接着进行下一次是否执行循环的判定. .一

32、般形式:一般形式: continue;continue;5.8 break语句和语句和continue语句语句 continuecontinue语句和语句和breakbreak语句的区别语句的区别 continuecontinue语句只结束本次循环,而不是终止整个循语句只结束本次循环,而不是终止整个循环的执行。环的执行。 while( (表达式表达式1) 1) for if( (表达式表达式2) 2) continue; 5.8 break语句和语句和continue语句语句 continuecontinue语句和语句和breakbreak语句的区别语句的区别 breakbreak语句则是结束

33、整个循环过程,不再判断执行循语句则是结束整个循环过程,不再判断执行循环的条件是否成立。环的条件是否成立。while( (表达式表达式1) 1) for if( (表达式表达式2) 2) break; 5.8 break语句和语句和continue语句语句 例例5.5 把把100200之间的不能被之间的不能被3整除的数输出。整除的数输出。 #include void main() int n; for(n=100;n=200;n+) if (n%3=0) continue; printf(%d”,n); 说明:说明:当当n能被能被3整除时,执整除时,执行行continue语句,结束本次语句,结束

34、本次循环(即跳过循环(即跳过printf函数语函数语句),只有句),只有n不能被不能被3整除时整除时才执行才执行printf函数。函数。5.9 程序举例程序举例例例5.6 用用/41-1/3+1/5-1/7+公式求公式求的近似值,的近似值,直到某一项的绝对值小于直到某一项的绝对值小于0.000001为止。为止。例例5.6 求求pi的近似值的近似值 #include #includevoid main() int s; float n,t,pi; t=1; pi=0; n=1.0; s=1; while(fabs(t)1e-6) pi=pi+t; n=n+2; s=-s; t=s/n; pi=p

35、i*4; printf(“pi=%10.6fn”,pi);运行结果:运行结果: pi= 3.1415945.9 程序举例程序举例例例5.7 求求Fibonacci数列前数列前40个数。这个数列有如下特个数。这个数列有如下特点:第点:第1,2两个数为两个数为1,1。从第。从第3个数开始,该数是个数开始,该数是其前面两个数之和。即其前面两个数之和。即:F(1)=1 (n=1)F(2)=1 (n=2)F(n)=F(n-1)+F(n-2) (n3) 5.9 程序举例程序举例例例5.7 求求Fibonacci数列前数列前40个数。个数。 #include void main() long int f1,

36、f2; int i; f1=1;f2=1; for(i=1; i=20; i+) printf(“%12ld %12ld”,f1,f2); if(i%2=0) printf(“n”); f1=f1+f2; f2=f2+f1; 运行结果:运行结果: 1 1 2 3 5 8 13 21 34 55 89 144 233 377 610 987 1597 2584 4181 6765 10946 17711 28657 46368 75025 121393 196418 317811 514229 832040 1346269 2178309 3524578 57022887 9227465 149

37、30352 24157817 39088169 63245986 102334155 5.9 程序举例程序举例例例5.8 判断判断m是否素数。是否素数。算法思想:算法思想: 让让m被被2倒除,如果倒除,如果m能被能被2k之中任何一个整数整之中任何一个整数整除,则提前结束循环,此时除,则提前结束循环,此时i必然小于或等于必然小于或等于k(即即);如果如果m不能被不能被2k(即即)之间的任一整数整除,则在完之间的任一整数整除,则在完成最后一次循环后,成最后一次循环后,i还要加还要加1,因此,因此i=k+1,然后才,然后才终止循环。在循环之后判别终止循环。在循环之后判别i的值是否大于或等于的值是否大

38、于或等于k+1,若是,则表明未曾被,若是,则表明未曾被2k之间任一整数整除过,之间任一整数整除过,因此输出因此输出“是素数是素数”。 k的取值:的取值:k=m-1 或或 k=sqrt(m)都可以都可以5.9 程序举例程序举例例例5.8 判断判断m是否素数。是否素数。 #include #include void main() int m,i,k; scanf(“%d”,&m); k=sqrt(m); for(i=2;ik) printf(“%d is a prime numbern”,m); else printf(%d is not a prime numbern”,m); 运行结果:运行结

39、果: 17 17 is a prime number 5.9 程序举例程序举例例例5.9 求求100200间的全部素数。间的全部素数。#include # include void main() int m,k,i,n=0; for(m=101;m=200;m=m+2) k=sqrt(m); for (i=2;i=k+1) printf(%d ”,m); n=n+1; if(n%10=0) printf(“n”); printf (n); 运行结果:运行结果: 101 103 107 109 113 127 131 137 139 149151 157 163 167 173 179 181

40、191 193 197199 5.9 程序举例程序举例例例5.10 译密码。为使电文保密,往往按一定规律将其译密码。为使电文保密,往往按一定规律将其转换成密码,收报人再按约定的规律将其译回原文。转换成密码,收报人再按约定的规律将其译回原文。例如:例如:可以按以下规律将电文变成密码:可以按以下规律将电文变成密码: 将字母将字母A变成字母变成字母E,a变成变成e,即变成其后的第,即变成其后的第4个个字母,字母,W变成变成A,X变成变成B,Y变成变成C,Z变成变成D。5.9 程序举例程序举例例例5.10 输入一行字符,要求输出其相应的密码输入一行字符,要求输出其相应的密码#include void main() char c; while(c=getchar()!=n) if(c=a & c=A & cZ & cz) c=c-26; printf(“%cn”,c); 运行结果:运行结果: China! Glmre!

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 研究生课件

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