第五六七章

第三章:分支结构 一、if分支结构 1. 基本if结构: (1) 导入包:   import java.util.Scanner;   import java.util.*; (2) 创建对象:   Scanner sc = new Scanner(System.in); (3) 使用:   int n = sc.nextInt();//输入一个整数   double d = sc.nextDouble();//输入 一个小数   String s = sc.next();// 输入一个字 符串   char c = sc.next().charAt(0);//输 入一个字符  2. 基本if结构2 3. 多重的if结构 (1) 语法:   if(判断条件/布尔表达式){       // 语句   } (2) 执行原理:如果判断条件成立,则执行{}中的 语句 (1) 语法:   if(判断条件/布尔表达式){       // 语句1   }else{       // 语句2   } (2) 执行原理:如果if条件成立,则执行语句1, 否则执行语句24. if嵌套结构 (1) 语法:   if(判断条件1){       // 语句1   }else if(判断条件2){       // 语句2   }else if(判断条件3){       // 语句3   }else{       // 语句n   } (2) 执行原理:从上往下依次判断,哪一个条件成 立,则执行对应{}中的语句  二、等值分支结构(switch...case结构) 1. 语法: (1) 语法:   if(判断条件/布尔表达式){       if(判断条件/布尔表达式){           //       }else if(判断条件){                   }else{}   }else {           }2. 执行原理: 3. 细节: switch(表达式){   case 值1:语句1;break;   case 值2:语句2;break;   case 值3:语句3;break;   ...   default:语句n;break; } 首先获取switch()中表达式的结果,根据结果从 上往下进行匹配case后面的值,结果和哪一个 case的值相等,则执行对应的后面的语句;如果都 不相等,则执行default后面的语句 (1) 表达式的结果类型:byte、short、int、 char、String (2) break:终止switch结构,防止case穿透 (3) default没有位置先后要求  三、局部变量 1. 概念:定义在函数/方法内部的变量 2. 特点:   第四章:循环结构 一、理解: 1. 循环:通过某个条件,重复并且有规律的执行一 段代码 (1) 必须先赋值,再使用   报错:可能尚未初始化变量 (2) 作用范围:从定义位置开始,到定义它的代码 块结束   报错信息为:找不到符号 (3) 在重合的作用范围内,不允许命名冲突   报错信息为:已在方法xxx中定义了变量 xx2. 循环组成部分:循环变量的初始化、循环条件、 循环变量的改变、循环体 3. 循环分类:while循环、do..while循环、for循环   二、while循环 1. 语法:   2. 执行原理: // 循环变量的初始化 while(循环条件){   // 循环体   // 循环变量改变 }3. 循环特点:   三、do..while循环 1. 语法: 先执行循环变量的初始化,接着判断循环条件,如 果循环条件满足——结果为true,则执行循环体,然 后执行循环变量的改变,接着再次判断循环条件, 如果满足——true,则再次执行循环体,同时循环变 量进行改变...直到循环条件不满足-结果为 false,则终止、跳出循环结构。 (1) 先判断,再执行,执行次数:0~n次 (2) 如果程序写的不合适,可能会出现死循环 // 循环变量的初始化 do{   // 循环体   // 循环变量的改变 }while(循环条件); // 分号不能省  2. 执行原理:   3. 特点:先执行,再判断,执行次数为1~n次。   四、for循环 1. 语法: 2. 执行原理: 先执行循环变量的初始化,然后执行循环体,接着 对循环变量进行改变,判断循环条件,满足-结果为 true,则再次的执行循环体,对循环变量进行概 念,判断循环条件....直到循环条件结果为 false,结束、跳出循环结构。 for(循环变量的初始化;循环条件;循环变量的改 变){   // 循环体 }3. 执行特点: (1) 先判断,再执行,执行次数 0~n次 (2) for()中的循环变量初始化可以定义在外面, 但是变量的作用范围扩大了 (3) for中的判断条件如果为空语句,则默认结果 为true  五、循环控制语句 【开发+面试+考试重点】 1. break:终止、结束当前循环结构;可以应用在 swtich..case结构中,防止case穿透 2. continue:中止、结束本次循环,从而进入下一 次循环   六、循环的嵌套 1. 理解:在循环结构中,定义一个完整的循环结构 循环总结: while和for:循环特点相同 先判断,再执行 do...while:先执行,再判断 实际开发:for循环比较常用 while循环:循环次数不明确时,建议使用while 循环 for循环:循环次数明确时,建议使用for2. 循环的次数:外层循环次数*内层循环次数 3. 循环控制语句应用的嵌套中: 4. 利用循环结构打印图形:外层循环控制行数、内 层循环控制列数     第五章:函数 一、函数 1. 理解:执行一段特定功能的代码,并且可以通过 名字进行反复的调用 2. 函数的使用流程: 外层循环和内层循环 break:终止、结束本层循环 continue:中止、结束本层本次循环  3. 函数的定义位置:定义类以内,其他函数以外的 位置(与main函数并列)   二、函数的基本使用 1. 函数的定义: (1) 函数的定义:确定函数的功能和函数名       a. 函数的声明:确定函数的名字       b. 函数的实现:确定函数的功能     (2) 函数的调用:通过名字进行反复的使用  2. 函数的调用:   三、参数的使用 public static void 函数名(){   // 函数的实现 } 函数的定义:函数的声明和函数的实现二、函数的基本使用 1. 函数的定义: (1) 函数的定义:确定函数的功能和函数名       a. 函数的声明:确定函数的名字       b. 函数的实现:确定函数的功能     (2) 函数的调用:通过名字进行反复的使用  2. 函数的调用:   三、参数的使用 public static void 函数名(){   // 函数的实现 } 函数的定义:函数的声明和函数的实现 (1) 函数的声明:   public static void 函数名()   注意:函数名 ,望文生义,采用驼峰命名法 形式命名 (2) 函数的实现:{} (1) 通过函数名直接使用函数对应的功能 (2) 语法:函数名();1. 多数情况下,函数与调用者之间需要数据的交 互;调用者必须提供必要的数据,才能使函数完 成相应的功能,调用者和函数之间交互的数据, 称为参数 2. 形式参数:   3. 实际参数: (1) 形式参数:简称形参,函数和调用者之间的一 种约定,约定了调用者需要给函数传递什么数据 (2) 定义:   public static void 函数名(数据类型 变量名,数据类型 变量名,数据类型 变量名3){           } (3) 使用:形参相当于 函数内部的局部变量 (4) 一个函数可以定义多个形参,称为形参列表 (0~n个)    四、函数的返回值 1. 理解:函数和调用者之间的一种数据交互,调用 者通过函数获取一些数据结果(函数给调用者一 定的结果) 2. 返回值的语法: (1) 实际参数:简称实参,函数调用时,传递的数 据 (2) 实参的作用:给形参赋值 (3) 注意:实参的个数、顺序、数据类型必须和形 参一致 定义一个函数selectMax,接收两个整数m,n,打 印两个数据中的较大值;在main函数中调用此函数3. 函数的返回值分类:   4. 函数返回值的处理: public static 函数返回值 函数名(形参列表) {   // 函数的实现、函数体 } (1) 返回值类型为:void,代表函数没有返回 值,函数不需要给调用者任何结果返回   public static void 函数名(参数){} (2) 返回值类型为:8种基本数据类型或是对象, 代表函数有返回值,函数必须给调用者返回值对应 类型的数据   public static 返回值类型 函数名(参数) {       return xxx;   }   5. return的作用:   五、函数的执行机制 1. 理解:   (1) 第一种处理方式:定义同类型的变量接收返回 值 (2) 第二种处理方式: (1) 将函数返回值进行返回值给调用者 (2) 结束当前的函数 程序以Main函数作为入口,进入main函数从上往 下依次执行,如果遇到函数的调用,则优先执行被 调用的函数内部代码,被调用函数执完毕之后,带 着带着返回值返回到调用为止,继续后续代码内容2. 函数的嵌套调用:被调用的函数内部,又调用了 其他的函数   六、递归调用 1. 理解:一个函数中调用自身函数 2. 注意:如果使用递归解决问题,必须给递归设置 一个出口,否则出现无穷递归,最终运行报错, 错误信息为: java.lang.StackOverflowError(栈溢出) 3. 递归的思想: 4. 案例: (1) 递进:每一次推进,计算都比上一次变得简 单,直至简单到无需继续推进,就能获得结果。也 叫到达出口。 (2) 回归:基于出口的结果,逐层向上回归,依次 计算每一层的结果,直至回归到最顶层。  package demo; public class Test6{ public static void main(String[] args){ int r =jieCheng(8); System.out.println(r); } // 函数功能:计算 n的阶乘 public static int jieCheng(int n) { // n的阶乘 = n * n-1 的阶乘 // 设置一个出口,当 n=1 或是0 , 结果直接为1 if(n==1 || n==0) return 1; return n * jieCheng(n-1); } }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值