目录
break
看下面一个需求:
随机生成 1-100 的一个数,直到生成了 97 这个数,看看你一共用了几次? 提示使用 (int)(Math.random() * 100) + 1
思路分析: 循环,但是循环的次数不知道. -> break ,当某个条件满足时,终止循环 通过该需求可以说明其它流程控制的必要性,比如 break
基本介绍:
break 语句用于终止某个语句块的执行,一般使用在 switch 或者循环【for , while , do-while】
基本语法:
{ ……
break;
……
}
以 while 使用 break 为例,画出示意图
注意事项和细节说明
continue
基本介绍:
(1)continue 语句用于结束本次循环,继续执行下一次循环。
(2)continue 语句出现在多层嵌套的循环语句体中时,可以通过标签指明要跳过的是哪一层循环 , 这个和前面的标签的使用的规则一样。
以 while 使用 continue 为例,画出示意图
return
return 使用在方法,表示跳出所在的方法,在讲解方法的时候,会详细的介绍,这里我们简单的提一下。注意:如果 return 写在 main 方法,退出程序..
本章练习:
1.编程实现如下功能【Homework01.java】
某人有100,000元,每经过一次路口,需要交费,规则如下:
(1) 当现金>50000时,每次交5%
(2) 当现金<=50000时,每次交1000
编程计算该人可以经过多少次路口, 要求: 使用 while + break方式完成
public class Homework01 {
//编写一个main方法
public static void main(String[] args) {
/*
某人有100,000元,每经过一次路口,需要交费,规则如下:
1) 当现金>50000时,每次交5%
2) 当现金<=50000时,每次交1000
编程计算该人可以经过多少次路口, 要求: 使用 while + break方式完成
思路分析
1. 定义 double money 保存 100000
2. 根据题的要求,我们分析出来有三种情况
money > 50000
money >=1000 && money <= 50000
money < 1000
3. 使用多分支 if-elseif-else
4. while+break[money < 1000], 同时使用一个变量count来保存通过路口
代码实现
*/
double money = 100000;//还有多少钱
int count = 0; //累积过的路口
while(true) { //无限循环
if(money > 50000) { //过路口
//money = money - money * 0.05;
money *= 0.95; //过了这个路口后,还有这么多钱
count++;
} else if(money >=1000) {
money -= 1000;
count++;
} else { //钱不够1000
break;
}
}
System.out.println("100000 可以过 " + count + " 路口..");
}
}
2.判断一个整数是否是水仙花数,所谓水仙花数是指一个3位数,其各个位上数字立方和等于其本身。例如: 153 = 1*1*1 + 3*3*3 + 5*5*5
public class Homework04 {
//编写一个main方法
public static void main(String[] args) {
/*
4. 判断一个整数是否是水仙花数,所谓水仙花数是指一个3位数,
其各个位上数字立方和等于其本身。
例如: 153 = 1*1*1 + 3*3*3 + 5*5*5
思路分析 => 多听. 见多识广..
1. 比如 int n = 153;
2. 先得到 n的百位,十位 ,各位的数字, 使用 if 判断他们的立方和是否相等
3. n的百位 = n / 100
4. n的十位 = n % 100 / 10
5. n的各位 = n % 10
6. 判断即可
*/
int n = 154;
int n1 = n / 100;
int n2 = n % 100 / 10;
int n3 = n % 10;
if(n1 * n1 * n1 + n2 * n2 * n2 + n3 * n3 * n3 == n) {
System.out.println(n + "是水仙花数");
} else {
System.out.println(n + "不是水仙花数");
}
}
}
3.输出1-100之间的不能被5整除的数,每5个一行
public class Homework06 {
//编写一个main方法
public static void main(String[] args) {
/*
输出1-100之间的不能被5整除的数,每5个一行
思路分析
1. 先输出1-100的所有数
2. 然后过滤输出 不能被5整除的数 i % 5 !=0
3. 每5个一行, 我们使用 int count 统计输出的个数 当 count%5=0就说明
输出了5个,这时,我们输出 一个换行即可控制
代码实现
*/
int count = 0; //统计输出的个数
for(int i = 1; i <= 100; i++) {
if(i % 5 != 0) {
count++;
System.out.print(i + "\t");
//判断, 每满5个,就输出一个换行..
if(count % 5 == 0) {
System.out.println();
}
}
}
}
}
4.输出小写的a-z以及大写的Z-A 。
public class Homework07 {
//编写一个main方法
public static void main(String[] args) {
//输出小写的a-z以及大写的Z-A
//考察我们对 a-z编码和 for的综合使用
//思路分析
//1. 'b' = 'a' + 1 c = 'a' + 2
//2. 使用for搞定
for(char c1 = 'a'; c1 <= 'z'; c1++) {
System.out.print(c1 +" ");
}
System.out.println("============");
//灵活的使用,编程..
for(char c1 = 'Z'; c1 >= 'A'; c1--) {
System.out.print(c1 +" ");
}
}
}
5.求出1-1/2+1/3-1/4…..1/100的和。
public class Homework08 {
//编写一个main方法
public static void main(String[] args) {
/*
求出1-1/2+1/3-1/4…..1/100的和
思路分析
1. 1-1/2+1/3-1/4…..1/100 = (1/1)-(1/2)+(1/3)-(1/4)...1/100
2. 从上面的分析我们可以看到
(1) 一共有100数 , 分子为1 , 分母从1-100
(2) 还发现 当分母为奇数时,前面是 +, 当分母是偶数时,前面是-
3. 我们可以使用 for + 判断即可完成
4. 把结果存放到 double sum
5. 这里有一个隐藏的陷阱,要把 公式分子 1 写出1.0 才能得到精确的小数
*/
double sum = 0;
for(int i = 1; i <= 100; i++) {
//判断是奇数还是偶数,然后做不同的处理
if( i % 2 != 0) {//分母为奇数
sum += 1.0/i;
} else { //分母我偶数
sum -= 1.0/i;
}
}
System.out.println("sum=" + sum);
}
}
6.求(1)+(1+2)+(1+2+3)+(1+2+3+4)+...+(1+2+3+..+100)的结果
public class Homework09 {
//编写一个main方法
public static void main(String[] args) {
//求(1)+(1+2)+(1+2+3)+(1+2+3+4)+...+(1+2+3+..+100)的结果
//
//思路分析
//1. 一共有100项相加
//2. 每一项的数字在逐渐增加
//3. 很像一个双层循环
//i 可以表示是第几项,同时也是当前项的最后一个数
//4. 使用 sum 进行累计即可
int sum = 0;
for(int i = 1; i <= 100; i++) {
for(int j = 1;j <= i; j++) {//内层对1-i进行循环
sum += j;
}
}
System.out.println("sum=" + sum);
}
}