程序的流程控制_第1页
程序的流程控制_第2页
程序的流程控制_第3页
程序的流程控制_第4页
程序的流程控制_第5页
已阅读5页,还剩52页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

会计学1程序的流程控制本章内容流程控制概述顺序控制选择控制循环控制无条件转移控制程序设计风格第1页/共57页流程控制概述表达式构成了数据处理的基本单位。当程序中有多个表达式时,就会面临:先计算哪一个表达式根据不同的情况计算不同的表达式一个或几个表达式需要重复计算多次语句实现对程序执行流程的控制,包括:顺序控制:按书写次序执行。选择控制:根据条件选择执行。循环控制:重复执行。第2页/共57页C++语句的分类第3页/共57页顺序控制按书写次序,从左到右、从上到下顺序执行。实现顺序控制的C++语句有:表达式语句复合语句空语句第4页/共57页

表达式语句在C++表达式的后面加上一个分号“;”就可以构成表达式语句,其格式为:<表达式>;例如:a+b*c;a>b?a:b;a++;x=a|b&c;

连续的多个表达式语句按它们的书写次序依次执行。第5页/共57页较常使用的表达式语句赋值自增/自减无返回值的函数调用,等输入/输出例如x=a+b;//赋值x++;//自增f(a);//函数调用cin>>a;//输入cout<<b;//输出第6页/共57页复合语句复合语句是由一对花括号括起来的一条或多条语句,又称为块(block)。语法上,复合语句可看作是一个语句。其格式为:

{<语句序列>}<语句序列>中的语句可以是任何的C++语句,其中包括数据定义和声明语句。复合语句中的语句序列一般按照书写次序执行。复合语句一般作为函数体和结构语句的成分语句。第7页/共57页复合语句举例{ inta,b;

cin>>a>>b; intmax; if(a>=b)//选择语句

max=a; else max=b; cout<<max<<endl;}第8页/共57页空语句根据程序设计的需要,在程序中的某些地方有时需要加上一些空操作,以方便其它流程控制的实现。空语句的格式为:

;空语句不做任何事情,其作用是用于语法上需要一条语句的地方,而该地方又不需做任何事情。空语句常常作为结构语句的子句。

第9页/共57页例如:{ ...... ...gotoend;//转向下面由语句标号end标识的空语句

...... end:;//空语句}其中,在“end:;”中,end是一个语句标号,“;”是一个空语句。再例如:inti,sum;for(sum=0,i=1;i<=100;sum+=i,i++);

其中,循环体为一条空语句第10页/共57页选择控制在程序中,常常需要根据不同的情况来从一组语句中选择一个来执行(分支),这是通过选择语句来完成的。选择语句包括:if语句switch语句第11页/共57页if语句if语句(又称条件语句)是根据一个条件满足与否来决定是否执行某个语句或从两个语句中选择一个语句执行。

if语句有两种格式:if(<表达式>)<语句>if(<表达式>)<语句1>else<语句2>其中的<语句>、<语句1>、<语句2>必须是一个语句!(复合语句算一个语句。)第12页/共57页if语句的含义第一种格式第二种格式第13页/共57页例子:从键盘输入三个整数,计算其中的最大值并将其输出#include<iostream>usingnamespacestd;intmain(){ inta,b,c,max; cout<<"请输入三个整数:"<<endl; cin>>a>>b>>c; if(a>b) max=a; else max=b; if(c>max)max=c; cout<<"最大者为:"<<max<<endl; return0;}第14页/共57页if语句的锯齿格式为了提高程序的易读性,在写if语句时,最好采用“锯齿”格式,即把成分语句往后缩进几列。当if语句的成分语句也是if语句时,如果嵌套层次很深,“锯齿”格式将会使得程序正文严重偏向右边,从而带来对程序编辑、查看带来困难。为了减少文本的缩进量,可以把这样的if语句按下面的格式书写:

if(...)...elseif(...)...elseif(...)...elseif(...)...else...if(...)...elseif(...)...elseif(...)...elseif(...)...else...等价于:第15页/共57页例子:从键盘输入一个三角形的三条边,判断其为何种三角形

#include<iostream>usingnamespacestd;intmain(){ inta,b,c; cin>>a>>b>>c; if(a+b<=c||b+c<=a||c+a<=b) cout<<"不是三角形"; elseif(a==b&&b==c) cout<<"等边三角形"; elseif(a==b||b==c||c==a) cout<<"等腰三角形"; elseif(a*a+b*b==c*c||b*b+c*c==a*a||c*c+a*a==b*b) cout<<"直角三角形(非等腰)"; else cout<<"其它三角形"; cout<<endl; return0;}第16页/共57页避免不必要的测试if(score>=90) cout<<"优";if(score>=80&&score<90) cout<<"良";if(score>=70&&score<80) cout<<"中";if(score>=60&&score<70) cout<<"及格";if(score<60) cout<<"不及格";第17页/共57页if语句的歧义问题下面的if语句的含义是什么?

if(<表达式1>)if(<表达式2>)<语句1>else<语句2>if(<表达式1>)if(<表达式2>)<语句1>else<语句2>if(<表达式1>)if(<表达式2>)<语句1>else<语句2>C++规定:else子句与它前面最近的、没有else子句的if配对。因此,上面的if语句解释为:if(<表达式1>)if(<表达式2>)<语句1>else<语句2>

若要按2来解释,则需要加上花括号(复合语句):if(<表达式1>){if(<表达式2>)<语句1>}else<语句2>第18页/共57页switch语句程序中有时需要从两个(组)以上的语句中选择一个(组)来执行。C++提供了一条多路选择语句:switch语句(又称开关语句),它能根据某个表达式的值在多组语句中选择一组语句来执行。每一组语句的最后一个语句往往是break语句。第19页/共57页switch语句的格式switch(<整型表达式>){ case<整型常量表达式1>:<语句序列1> case<整型常量表达式2>:<语句序列2>: case<整型常量表达式n>:<语句序列n> [default:<语句序列n+1>]}第20页/共57页例子、从键盘输入一个星期的某一天(0:星期天;1:星期一;...),然后输出其对应的英语单词#include<iostream>usingnamespacestd;intmain(){ intday; cin>>day; switch(day) { case0:cout<<"Sunday";break; case1:cout<<"Monday";break; case2:cout<<"Tuesday";break; case3:cout<<"Wednesday";break; case4:cout<<"Thursday";break; case5:cout<<"Friday";break; case6:cout<<"Saturday";break; default:cout<<"Inputerror"; } cout<<endl; return0;}第21页/共57页switch语句中使用break语句在执行switch语句的某个分支时,需要用break语句结束该分支的执行。在switch语句的一个分支的执行中,如果没有break语句(最后一个分支除外),则该分支执行完后,将继续执行紧接着的下一个分支中的语句序列。在其它一些语言(如:Pascal)的多路选择语句中,一个分支执行完后将自动结束多路选择语句的执行。C++中的switch语句比其它一些语言中的多路选择语句更具有灵活性。当若干个分支具有部分重复功能时,C++的switch语句可以节省代码量。第22页/共57页switch(...){ ... case<整型常量表达式1>:

A case<整型常量表达式2>:

B case<整型常量表达式3>:

C break; ...}上面的语句中,分支1执行A、B和C;分支2执行B和C;分支3执行C。(假设A、B中没有break语句)第23页/共57页循环控制如何编程计算n!(n是变量)?n!=n*(n-1)*(n-2)*...*2*1表达式中不允许有“...”上面的问题需要用重复操作控制来解决:对相同的操作重复执行多次,每一次操作的数据有所不同。f=1,对i=2~n,重复执行:f=f*i;循环语句为解决重复操作提供了一种途径。循环一般由四个部分组成:循环初始化循环条件循环体下一次循环准备。第24页/共57页C++提供了三种实现重复操作的循环语句:while语句do-while语句for语句第25页/共57页while语句while语句具有如下的格式:

while(<表达式>)<语句>第26页/共57页用while语句求n!#include<iostream>usingnamespacestd;intmain(){ intn; cin>>n; inti=2,f=1;//循环初始化

while(i<=n)//循环条件

{ f*=i; i++;//下一次循环准备

}//循环体

cout<<"factorialof"<<n<<"="<<f<<endl; return0;}第27页/共57页do-while语句do-while语句的格式如下:

do<语句>while(<表达式>);第28页/共57页用do-while语句求n!#include<iostream>usingnamespacestd;intmain(){ intn; cin>>n; inti=1,f=1;//循环初始化

do//循环体

{ f*=i; i++;//下一次循环的准备

}while(i<=n);//循环条件

cout<<"factorialof"<<n<<"="<<f<<endl; return0;}第29页/共57页for语句for语句的格式如下:

for(<表达式1>;<表达式2>;<表达式3>)<语句>第30页/共57页#include<iostream>usingnamespacestd;intmain(){ intn,i,f; cin>>n; for(i=2,f=1//循环初始化

; i<=n//循环条件

; i++)//下一次循环准备

f*=i;//循环体

cout<<"factorialof"<<n<<"="<<f<<endl; return0;}用for语句求n!第31页/共57页循环的种类计数控制的循环循环前就知道循环的次数,循环时重复执行循环体直到指定的次数事件控制的循环循环前不知道循环的次数,循环的终止是由循环体的某次执行导致循环的结束条件得到满足而引起的第32页/共57页三种循环语句的使用原则三种循环语句在表达能力上是等价的,在解决某个具体问题时,用其中的一种可能会比其它两种更加自然。一般来说,计数控制的循环一般用for语句;事件控制的循环一般用while或do-while语句,其中,如果循环体至少要执行一次,则用do-while语句。由于for语句能清晰地表示“循环初始化”、“循环条件”以及“下一次循环准备”,因此,一些非计数控制的循环也用for语句实现。第33页/共57页例:计算从键盘输入的一系列整数的和,要求首先输入整数的个数。(计数控制的循环)

#include<iostream>usingnamespacestd;intmain(){ intn; cout<<"请输入整数的个数:"; cin>>n; cout<<"请输入"<<n<<"个整数:"; intsum=0; for(inti=1;i<=n;i++) { inta; cin>>a; sum+=a; } cout<<"输入的"<<n<<"个整数的和是:"<<sum<<endl; return0;}第34页/共57页例:计算从键盘输入的一系列整数的和,要求输入以-1结束。(事件控制的循环)#include<iostream>usingnamespacestd;intmain(){inta,sum=0; cout<<"请输入若干个整数(以-1结束):"; cin>>a; while(a!=-1) { sum+=a; cin>>a; } cout<<"输入的整数的和是:"<<sum<<endl; return0;}第35页/共57页例:从键盘接收字符,一直到输入了字符y(Y)或n(N)为止。(事件控制的循环)#include<iostream>#include<cstdlib>usingnamespacestd;intmain(){ charch; do { cout<<"请输入Yes或No(y/n):"; cin>>ch; ch=tolower(ch); }while(ch!='y'&&ch!='n'); if(ch=='y') ...... else ...... return0;}第36页/共57页例:求第n个费波那契(Fibonacci)数//1,1,2,3,5,8,13,...#include<iostream>usingnamespacestd;intmain(){ intn; cin>>n; intfib_1=1;//第一个Fibonacci数

intfib_2=1;//第二个Fibonacci数

for(inti=3;i<=n;i++) { inttemp=fib_1+fib_2;//计算新的Fibonacci数

fib_1=fib_2;//记住新的前一个Fibonacci数

fib_2=temp;//记住新的Fibonacci数 }

cout<<"第"<<n<<"个费波那契数是:"<<fib_2<<endl; return0;}fib_2=fib_1+fib_2;//计算和记住新的Fibonacci数fib_1=fib_2-fib_1;//记住前一个Fibonacci数第37页/共57页循环优化问题算法的优化:减少循环次数避免在循环中重复计算不变的表达式第38页/共57页#include<iostream>usingnamespacestd;intmain(){ intn; cout<<"请输入一个正整数:" cin>>n;//从键盘输入一个正整数

for(inti=2;i<n;i++)//循环:分别判断2、3、...、n-1是否为素数

{ intj=2; while(j<i&&i%j!=0)//循环:分别判断i是否能被2~i-1整除

j++; if(j==i)//i是素数

cout<<i<<""; } cout<<endl; return0;}注意:1、上面的for循环中,偶数没有必要再判断它们是否为素数;

2、上面的while循环没有必要到i-1,只需要到:sqrt(i)例:编程求出小于n的所有素数(质数)第39页/共57页#include<iostream>#include<cmath>usingnamespacestd;intmain(){ intn; cin>>n;//从键盘输入一个数

if(n<2)return-1; cout<<2<<",";//输出第一个素数

for(inti=3;i<n;i+=2)//循环:分别判断3、5、...、是否为素数

{ intj=2; while(j<=sqrt(i)&&i%j!=0)//循环:分别判断i是否为素数

j++; if(j>sqrt(i))//i是素数

cout<<i<<","; } cout<<endl; return0;}注意:上面程序中的sqrt(i)被重复计算!第40页/共57页......intj=2,k=sqrt(i);while(j<=k&&i%j!=0) j++;if(j>k)//i是素数。......注意:对有些循环优化,编译器能实现!第41页/共57页无条件转移控制除了有条件的选择语句(if和switch)外,C++还提供了无条件的转移语句:gotobreakcontinuereturn第42页/共57页goto语句goto语句的格式如下:

goto<语句标号>;<语句标号>为标识符,其定义格式为:

<语句标号>:<语句>goto的含义是:程序转移到带有<语句标号>的语句第43页/共57页用goto语句求n!#include<iostream>usingnamespacestd;intmain(){ intn; cin>>n; inti=1,f=1;loop: f*=i; i++; if(i<=n)gotoloop; cout<<"factorialof"<<n<<"="<<f<<endl; return0;}第44页/共57页在使用goto语句时,应该注意:不能用goto语句从一个函数外部转入该函数的内部(函数体),也不能用goto语句从一个函数的内部转到该函数的外部。允许用goto语句从内层复合语句转到外层复合语句或从外层复合语句转入内层复合语句。goto语句不能掠过带有初始化的变量定义。第45页/共57页voidf(){ ...... gotoL1;//Error ......

while(...) { intx=0; L1:... ...... gotoL2;//Error ...... } ..... inty=10; L2:...... ......}第46页/共57页break语句break语句的格式:

break;break语句的含义有两个:结束switch语句的某个分支的执行退出包含它的最内层循环语句(由于循环可以嵌套)在循环体中只要执行了break语句,就立即跳出(结束)循环,循环体中跟在break语句后面的语句将不再执行,程序继续执行循环之后的语句。在循环体中,break语句一般作为某个if语句的子句,用于实现进一步的循环控制。第47页/共57页用goto语句实现break语句的功能while(...){ ...... ...break; ......}上述程序等价于:while(...){ ...... ...gotoL; ......}L:...第48页/共57页例如,判断i是否为素数的循环也可写成:j=2;k=sqrt(i);while(j<=k){ if(i%j==0)break;//退出循环

j++;}或for(j=2,k=sqrt(i);j<=k;j++) if(i%j==0)break;第49页/共57页continue语句continue语句的格式如下:

continue;continue语句只能用在循环语句的循环体中,其含义是:立即结束当前循环,准备进入下一次循环。对于while和do-while语句,continue语句将使控制转到循环条件的判断;对于for语句,continue语句将使控制转到:先计算<表达式3>,然后计算<表达式2>,并根据<表达式2>的计算结果来决定是进入下一次循环还是结束循环。

第50页/共57页用空语句和goto语句实现continue语句的功能while(...){ ...... ...continue; ......}上述程序等价于:while(...){ ...... .

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论