资源描述
单击此处编辑母版标题样式,单击此处编辑母版文本样式,第二级,第三级,第四级,第五级,*,第六章 循环型程序设计,6.1,概述,C,语言可实现循环的语句:,用,goto,和,if,构成循环,不要求,while,语句,do while,语句,for,语句,6.2goto,语句及用,goto,构成循环,,不,提倡,一般格式:,goto,语句标号;,.,标号:语句;,1,6.3 while,语句,记忆:先判条件,执行循环体一次,再判条件。不满足退出。关键:条件为非,0,while(,表达式,),循环体语句;,执行流程,:,expr,循环体,假(0),真(非0),while,(,表达式),2,特点:先判断表达式,后执行循环体,说明:,循环体有可能一次也不执行,循环体可为任意类型语句,下列情况,退出,while,循环,条件表达式不成立(为零),循环体内遇,break,return,goto,无限循环,:while(1),循环体,;,求,1+2+3,+100=?,3,P114,例,6.2,用,while,循环求,/*ch6_2.c*/,#include,main(),int,i,sum=0;,i=1;,while(i=100),sum=sum+i;,i+;,printf(%d,sum,);,循环初值,循环终值,循环变量增值,循环条件,循环体,4,例 显示,110,的平方,#include,main(),int,i=1;,while(i=10),printf(,%d,*,%d,=,%d,n,i,i,i*i);,i+;,运行结果:,1*1=1,2*2=4,3*3=9,4*4=16,5*5=25,6*6=36,7*7=49,8*8=64,9*9=81,10*,10,=100,5,6.4 dowhile,语句,一般形式:,do,循环体语句;,while(,表达式,);,执行流程,:,do,循环体,expr,假(0),真(非0),while,6,特点:先执行循环体,后判断表达式,说明:,至少执行一次循环体,dowhile,可转化成,while,结构,expr,循环体,假(0),真(非0),循环体,While,循环,7,P115,例,6.3,用,dowhile,循环求,/*ch6_3.c*/,#include,main(),int,i,sum=0;,i=1;,do,sum=sum+i;,i+;,while(i=100);,printf(%d,sum,);,8,P117,例,6.4 while,和,dowhile,比较,#include,main(),int,i,sum=0;,i=1;,do,sum=sum+i;,i+;,while(i=10);,printf(%d,sum,);,main(),int,i,sum=0;,i=1;,while(i=10),sum=sum+i;,i+;,printf(%d,sum,);,运行:,输入,1,输入,1,sum=55 sum=55,输入,11,输入,11,sum=0 sum=11,9,6.5 for,语句,一般形式:,for(,expr1,;,expr2,;,expr3,),循环体语句;,执行流程:,expr2,循环体,假(0),真(非0),for,expr1,expr3,10,for,语句一般应用形式,:,for(,循环变量赋初值;循环条件;循环变量增值),循环体语句;,说明:,for,语句中,expr1,expr2,expr3,类型任意,都可省略,但分号;不可省,无限循环,:for(;),for,语句可以转换成,while,结构,expr1;,while(expr2),循环体语句;,expr3;,例 用,for,循环求,#include,main(),int,i,sum=0;,for(,i=1,;,i=100,;,i+,),sum+=i;,printf(%d,sum,);,11,例:,#include,main(),int,i=0;,for(i=0;i10;i+),putchar(a+i,);,运行结果:,abcdefghij,例:,#include,main(),int,i=0;,for(;i10;i+),putchar(a+i,);,12,main(),int,i,j,k;,for(i=0,j=100;i=j;i+,j-),k=i+j;,printf(%d+%d,=%dn,i,j,k);,#include,main(),char c;,for(;(c=,getchar,()!=n;),printf(%c,c);,#include,main(),int,i,c;,for(i=0;(c=,getchar,()!=n;i+=3),printf(%c,i+c);,13,6.6,循环的嵌套,三种循环可互相嵌套,层数不限,外层循环可包含两个以上内循环,但不能相互交叉,嵌套循环的执行流程,嵌套循环的跳转,禁止:,从外层跳入内层,跳入同层的另一循环,向上跳转,如:,for(i=1;i10;i+),for(j=1;j10;j+),第一句,;,第二句,;,14,例 循环嵌套,输出九九表,1,2,3,4,5,6,7,8,9,1,2,3,4,5,6,7,8,9,2,4,6,8,10,12,14,16,18,3,6,9,12,15,18,21,24,27,9,18,27,36,45,54,63,72,81,.,i,j,/*ch6_5.c*/,#include,main(),int,i,j;,for(i=1;i10;i+),printf(%4d,i);,printf(n-n,);,for(i=1;i10;i+),for(j=1;j10;j+),printf(j,=9)?%4dn:%4d,i*j);,15,i10,s=s+i+j,假(0),真(非0),i=1,j+,j=1,j10,真(非0),假(0),i+,for(i=1;i=10;i+),for(j=1;j=10;j+),s=s+i+j;,printf(“%dn,s,);,分析技术:,先固定外层,i,,,再分析内层,j,。,把二重循环转为单循环,j,而后再执行外循环,i,。,外循环,内循环,16,6,.,7,几种循环的比较,可代替使用,;,while,及,dowhile,的,循环体内要有,i+,,,for(),则不用,但,(),内要有,i+,。,6,.,8,break,和,continue,break,语句,功能:在循环语句和,switch,语句中,终止并跳出循环体或开关体,说明:,break,只能,终止并跳出,最近一层,的结构,break,不能用于循环语句和,switch,语句之外的任何其它语句之中,continue,语句,功能:跳过后面语句,直接拉回到循环开始处,进行下次循环的操作。,短路,17,expr,break;,假(0),真(非0),while,do,break;,.,expr,假(0),真(非0),while,18,expr2,break;,.,假(0),真(非0),for,expr1,expr3,switch,expr,语句组,1,break;,语句组,2,break;,语句组,n,break;,语句组,break;,.,const 1,const 2,const n,default,case,19,例,break,举例:输出圆面积,面积大于100时停止,#define PI 3.14159,main(),int,r;,float area;,for(r=1;r100),break;,printf(r,=%d,area=%.2fn,r,area);,思考:,r,是整型,,PI,是浮点常量,,area=PI*r*r,能放一起运算吗?其值是什么类型的?为什么?,20,例,break,举例:小写字母转换成大写字母,直至输入非字母字符,main(),int,i,j;,char c;,while(1),c=,getchar,();,if(c=a&c=z),putchar(c-32);,else,break;,思考:本循环的执行条件是什么?退出条件?,c,在接收一个小写字母后,为何能进行,c=c-32,运算,其原理及结果是什么?,21,continue,语句,功能:结束本次循环,跳过,循环体中,尚未执行的语句,进行下一次是否执行循环体的判断,仅用于循环语句中,expr,continue;,假(0),真(非0),while,真(非0),do,continue;,.,expr,假(0),while,expr2,continue;,.,假(0),真(非0),for,expr1,expr3,22,例 求输入的十个整数中正数的个数及其平均值,main(),int,i,num=0,a;,float sum=0;,for(i=0;i10;i+),scanf(%d,&a,);,if(a=0)continue;,num+;,sum+=a;,printf(%d,plus integers sum:%6.0fn,num,sum);,printf(Mean,value:%6.2fn,sum/num);,sum,、,num,、,a,之间运算的原理是什么?,23,程序举例,#include,#include,main(),int,s=1;,float n=1.0,pi=0.0,t=1.0;,while(fabs(t,)1e-6),pi=pi+t;,n=n+2;,s=-s;,t=s/n;,pi=pi*4;,printf(pi,=%10.6fn,pi);,结果:,3.141594,改,long,及,1e-8,及输出,%20.17f,结果:,3.1415926335902506,24,P125,例,6.7,求,Fibonacci,数列:1,1,2,3,5,8,的前,1,0个数,main(),int,f1,f2,i;,f1=1;f2=1;,clrscr,();,for(i=1;i=5;i+),printf,(%d%d,f1,f2);,f1=f1+f2;,f2=f2+f1;,sleep(3);,25,P127,例,6.9,求,100,以内,素数,main(),int,m,k,i,j=0;clrscr();,for(m=1;m=100;m+=2),k=m;,for(i=2;i=k),printf(%d,m);j+;,printf(n%d,j,);,1 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97,#include,#include,main(),int,m,k,i,n=0,j=0;,clrscr,();,for(m=2;m=100;m=m+1),k=,sqrt(m,);,for(i=2;i=k+1),printf(%d,m);j=j+1;,printf(%dn,j,);,思考,:,为何要包含,math.h,?,26,P126,记忆:求素数的另一方法,重要!,#include stdio.h,void main(),int m,k,i,j=0;,for(m=101;m=200;m+),if(isP(m),printf(%d,m);j+;,printf(n%d,j);,int isP(int m),int i;,for(i=2;i=a&c=A&c=Z&c=z),c=c-26;,printf(%c,c,);,printf(n,);,sleep(3);,输入,China!,输出,Glmre,!,ABCDEFGHIJKLMNOPQRSTUVWXYZ,28,记忆要点,1.while,循环(由,if,语句推出),while(,条件,),-;,2.dowhile,循环(由,while,推出),do,-;,while(,条件,);,3.for,循环,for(i=1;i=100;i+),-;,前条件、后条件、中条件位置。,Break,、,continue,退出,典型:求,1+2+100,、阶乘,29,
展开阅读全文