程序控制结构及实例_第1页
程序控制结构及实例_第2页
程序控制结构及实例_第3页
程序控制结构及实例_第4页
程序控制结构及实例_第5页
已阅读5页,还剩12页未读 继续免费阅读

下载本文档

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

文档简介

程序控制结构及实例第1页,课件共17页,创作于2023年2月目标掌握每种语句的格式及语法结构运用循环语句实现循环结构的程序设计具备初步描述算法的能力第2页,课件共17页,创作于2023年2月循环结构循环结构是指在一定的条件下反复执行某段程序,被反复执行的这段程序称为“循环体”。

Java中有三种语句来实现循环结构,分别是while、do-while和for语句。它们的结构分别如下图所示。第3页,课件共17页,创作于2023年2月while语句while语句的格式如下:

while(条件表达式){

循环体语句;

}在循环刚开始时,会计算一次“条件表达式”的值。当条件为假时,将不执行循环体,直接跳转到循环体外,执行循环体外的后续语句;当条件为真时,便执行循环体。每执行完一次循环体,都会重新计算一次条件表达式,当条件为真时,便继续执行循环体,直到条件为假才结束循环。【例4.4】用while语句计算10的阶乘cha=0; //b-awhile(a<b){cha++;a++; }System.out.print(cha);第4页,课件共17页,创作于2023年2月do-while语句do-while语句的格式如下:

do{

循环体语句;

}while(条件表达式);

do-while循环与while循环的不同在于:它先执行循环中的语句,然后再判断条件是否为真,如果为真则继续循环;如果为假,则终止循环。因此,do-while循环至少要执行一次循环语句。【例4.5】用do-while语句计算10的阶乘第5页,课件共17页,创作于2023年2月for语句for语句是三个循环语句中功能最强,使用最广泛的一个。for语句的格式如下:

for(表达式1;表达式2;表达式3){

循环体语句;

}表达式1一般是一个赋值语句,它用来给循环控制变量赋初值;表达式2是一个布尔类型的表达式,它决定什么时候退出循环;表达式3一般用来修改循环变量,控制变量每循环一次后按什么方式变化。这三个部分之间用“;”分开。第6页,课件共17页,创作于2023年2月for语句的执行过程for(intcha=0;a<b;a++)cha++;(1)在循环刚开始时,先计算表达式1,在这个过程中,一般完成的是初始化循环变量或其它变量。(2)根据表达式2的值来决定是否执行循环体。表达式2是一个返回布尔值的表达式,若该值为假,将不执行循环体,并退出循环;若该值为真,将执行循环体。(3)执行完一次循环体后,计算表达式3。在这个过程中一般会修改循环变量。(4)转入第(2)步继续执行。【例4.6】用for语句计算10的阶乘第7页,课件共17页,创作于2023年2月跳转语句跳转语句用来实现循环执行过程中的流程转移。在switch语句中使用过的break语句就是一种跳转语句。在Java语言中,有两种跳转语句:break语句和continue语句。在Java语言中,可用break和continue控制循环的流程。其中,break用于强行退出循环,不执行循环中剩余的语句。而continue则停止执行当前的循环,开始新的循环。第8页,课件共17页,创作于2023年2月break语句作用:使程序的执行流程从一个语句块内部转移出去。它只在switch语句和循环语句中使用,允许从switch语句的case子句中跳出,或从循环体内跳出分为带标号和不带标号两种形式:break[标号名];带标号的break语句可以从多重循环体的最内部跳出所有的循环,而不带标号的break语句只能跳到当前循环外层Label:for(inta=0;a<4;a++){for(intj=0;j<2;j++){

if(a=2) break

Label;

System.out.print (a*2+j+”\t”);

}System.out.println(“a=“+a);第9页,课件共17页,创作于2023年2月continue语句continue语句只能用在循环语句中,作用是终止当前这一轮循环,不再执行在它后面的语句,直接进入下一轮的循环。continue语句具有带标号和不带标号两种形式:continue[标号名];标号名必须放在循环语句之前,用于标志这个循环体在while和do…while循环中,不带标号的continue语句使程序流程直接跳到循环条件的判断上;在for循环中,不带标号的continue语句直接计算表达式3的值,再根据表达式2的值决定是否继续循环。第10页,课件共17页,创作于2023年2月

//文件名Ex4_10publicclassEx4_10{publicstaticvoidmain(String[]args){ intj;for(j=1;j<=10;j++){ if(j==5) continue; System.out.print(j+","); } }}输出整数1,2,3,4,6,7,8,9,10第11页,课件共17页,创作于2023年2月递归在方法体内可以调用其他方法,方法体内也可以调用该方法本身,即方法自己调用自己,我们称自己直接或间接调用自己的方法为递归方法。在方法体内调用该方法本身的过程,称为方法的递归调用。下面我们通过分析Fibonacci序列介绍递归方法。Fibonacci序列:1,1,2,3,5,8,13,21,34,……以1和1开始,每个后续数字是序列中前两个数字的和。这个序列可以被递归地定义为下面的形式。

f(0)=1;f(1)=1;f(n)=f(n-2)+f(n-1);n>=2用递归方法计算Fibonacci序列第20项第12页,课件共17页,创作于2023年2月求50到100(包含50和100)之间的素数并输出素数是指除1和它本身是该数的因子外,没有别的因子的自然数。分析(自顶向下,逐步求精):循环变量i从50循环到100,每次增1,判断i是否是素数要判断某个数i是否为素数,设置变量j从2循环到(i-1),判断j是否为i的因子。若i有因子j,则不是素数。判断j是否为i的因子的方法,如果表达式(i%j==0)为true,说明i能被j整除,则j是i的因子结论:这个问题可以通过两层循环实现,外层递增被判断的数字i;内层循环判断变量i是否为素数。第13页,课件共17页,创作于2023年2月publicclassEx4_13{publicstaticvoidmain(Stringargs[]){inti,j;next:for(i=50;i<=100;i++){for(j=2;j<i-1;j++){if(i%j==0)continuenext;}System.out.println(i);}}}例4.13代码第14页,课件共17页,创作于2023年2月求两个给定正数的最大公约数和最小公倍数最大公约数——辗转相除法(欧几里德算法)余数1=大数%小数余数2=小数%余数1余数3=余数1%余数2直至余数为0,则最后一个除数为所求最小公倍数:大数*小数/最大公约数……第15页,课件共17页,创作于2023年2月内容回顾本章首先介绍基本的控制结构,接下来讨论选择语句、循环语句、break语句、continue语句和递归等。虽然Java语言是面向对象的程序设计语言,但是面向对象的编程也是以面向过程编程为基础而发展起来的,在对象的方法等程序片内部,仍然需要严格遵守传统的结构化程序

温馨提示

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

评论

0/150

提交评论