Java EE-训练

设计知识点: 变量、数组 运算符:基本运算符、关系运算符、逻辑运算符… 程序流程控制:if switch for while ;死循环、循环嵌套 跳转关键字:break continue return 方法

1.买飞机票

需求:

机票价格按照淡季旺季、头等舱和经济舱收费、输入机票原价、月份和头等舱或经济舱。 按照如下规则计算机票价格:旺季( 5-10 月)头等舱 9 折,经济舱 8.5 折,淡季( 11 月到来年 4 月)头等舱 7 折,经济舱 6.5 折。

 分析:

定义一个方法可以进行键盘录入机票原价、月份和机舱类型。 使用 if 判断月份是是旺季还是淡季,使用 switch 分支判断是头等舱还是经济舱。 选择对应的折扣进行计算并返回计算的结果。

 

import java.util.Scanner;/**需求:机票价格按照淡季旺季、头等舱和经济舱收费、输入机票原价、月份和头等舱或经济舱。按照如下规则计算机票价格:旺季(5-10月)头等舱9折,经济舱8.5折,淡季(11月到来年4月)头等舱7折,经济舱6.5折。*/
public class Test1 {public static void main(String[] args) {// 3、录入购买信息,调用方法得到最终结果Scanner sc = new Scanner(System.in);System.out.println("机票原价:");double price = sc.nextDouble();System.out.println("月份:");int month = sc.nextInt();System.out.println("仓位类型(头等舱、经济舱):");String type = sc.next();double rs = calc(price, month, type);System.out.println("您当前购买机票的价格是:" + rs);}/**1、定义一个方法:形参(原价、月份、头等舱经济舱) 返回值类型申明:double*/public static double calc(double money, int month, String type){// 2、判断月份是淡季还是旺季if(month >= 5 && month <= 10){// 旺季switch (type){case "经济舱":money *= 0.85;break;case "头等舱":money *= 0.9;break;default:System.out.println("您输入的仓位不正确~~");money = -1; // 当前无法计算价格了!}}else if(month == 11 || month == 12 || month >= 1 && month <= 4){switch (type){case "经济舱":money *= 0.65;break;case "头等舱":money *= 0.7;break;default:System.out.println("您输入的仓位不正确~~");money = -1; // 当前无法计算价格了!}}else {System.out.println("月份有问题");money = -1;}return money;}
}

1.遇到判断值匹配的时选择什么结构实现?

        使用switch分支结构实现。

2.遇到判断区间范围的时候选择什么结构实现?

        使用if分支结构实现。 

2. 找素数

 判断101-200之间有多少个素数,并输出所有素数?

说明

素数:如果除了1和它本身以外,不能被其他正整数整除,就叫素数。

分析

101-200之间的数据可以采用循环依次拿到; 每拿到一个数,判断该数是否是素数。

判断规则是:从2开始遍历到该数的一半的数据,看是否有数据可以整除它,有则不是素数,没有则是素数

/**需求:找出101-200之间的素数输出:素数是什么:如果除了1和它本身以外,不能被其他正整数整除,就叫素数。*/
public class Test2 {public static void main(String[] args) {// 1、定义一个循环,找到101-200之间的全部数据for (int i = 101; i <= 200 ; i++) {// i = 101 102 103 ... 199 200// 信号位:标记boolean flag = true; // 一开始认为当前数据是素数。// 2、判断当前遍历的这个数据是否是素数for (int j = 2; j < i / 2; j++) {if(i % j == 0){flag = false; // 假设失败了,i不是素数break; // 没有必要继续判定下去了!}}// 3、根据判定的结果选择是否输出这个数据,是素数则输出if(flag){System.out.print(i + "\t");}}}
}

3. 开发验证码

需求:

定义方法实现随机产生一个 5 位的验证码,每位可能是数字、大写字母、小写字母。 

分析:

定义一个方法,生成验证码返回:方法参数是位数、方法的返回值类型是 String 在方法内部使用 for 循环生成指定位数的随机字符,并连接起来。把连接好的随机字符作为一组验证码进行返回。

 

import java.util.Random;/**需求:定义方法实现随机产生一个5位的验证码,每位可能是数字、大写字母、小写字母。*/
public class Test3 {public static void main(String[] args) {// 4、调用获取验证码的方法得到一个随机的验证码String code = createCode(5);System.out.println("随机验证码:" + code); }/**1、定义一个方法返回一个随机验证码:是否需要返回值类型申明?String  是否需要申明形参:int n*/public static String createCode(int n){// 3、定义一个字符串变量记录生成的随机字符String code = "";Random r = new Random();// 2、定义一个for循环,循环n次,依次生成随机字符for (int i = 0; i < n; i++) {// i = 0 1 2 3 4// 3、生成一个随机字符:英文大写 小写 数字 (0 1 2)int type = r.nextInt(3); // 0  1  2switch (type){case 0:// 大写字符(A 65 - Z 65+25)  (0 - 25) + 65char ch = (char) (r.nextInt(26) + 65);code += ch;break;case 1:// 小写字符(a 97 - z 97+25)  (0 - 25) + 97char ch1 = (char) (r.nextInt(26) + 97);code += ch1;break;case 2:// 数字字符code += r.nextInt(10); // 0 - 9break;}}return code;}
}

 随机验证码的核心实现逻辑是如何进行的?

定义一个 String 类型的变量存储验证码字符。定义一个 for 循环,循环 5 次。随机生成 0|1|2 的数据,依次代表当前位置要生成数字 | 大写字母 | 小写字母。 0 1 2 交给 switch 生成对应类型的随机字符,把字符交给 String 变量。循环结束后,返回 String 类型的变量即是所求的验证码结果。 

4.数组元素的复制

需求:

l 把一个数组中的元素复制到另一个新数组中去。

分析:

需要动态初始化一个数组,长度与原数组一样。 遍历原数组的每个元素,依次赋值给新数组。 输出两个数组的内容。

 

/**需求:把一个数组中的元素复制到另一个新数组中去。*/
public class Test4 {public static void main(String[] args) {int[] arr1 = {11, 22, 33, 44};// int[] arr2 = arr1; // 没有完成了数组复制。int[] arr2 = new int[arr1.length];copy(arr1 , arr2);printArray(arr1);printArray(arr2);}public static void printArray(int[] arr){System.out.print("[");for (int i = 0; i < arr.length; i++) {System.out.print(i == arr.length - 1 ? arr[i] : arr[i] + ", ");}System.out.println("]");}public static void copy(int[] arr1, int[] arr2){// 正式完成元素的复制for (int i = 0; i < arr1.length; i++) {arr2[i] = arr1[i];}}
}

数组的拷贝是什么意思?

需要创建新数组,把原来数组的元素赋值过来。

5.评委打分

需求

在唱歌比赛中,有6名评委给选手打分,分数范围是[0 - 100]之间的整数。选手的最后得分为:去掉最高分、最低分后的4个评委的平均分,请完成上述过程并计算出选手的得分。

 分析:

6 个评委的分数录入到程序中去 ----> 使用数组 int [] scores = new int[6];遍历数组中每个数据,进行累加求和,并找出最高分、最低分。按照分数的计算规则算出平均分。

 

import java.util.Scanner;/**需求:在唱歌比赛中,有6名评委给选手打分,分数范围是[0 - 100]之间的整数。选手的最后得分为:去掉最高分、最低分后的4个评委的平均分,请完成上述过程并计算出选手的得分。*/
public class Test5 {public static void main(String[] args) {// 1、定义一个动态初始化的数组,用于后期录入6个评委的分数int[] scores = new int[6];// 2、录入6个评委的分数Scanner sc = new Scanner(System.in);for (int i = 0; i < scores.length; i++) {System.out.println("请您输入第" + (i + 1) +"个评委的打分:");int score = sc.nextInt();// 3、把这个分数存入到数组的对应位置处scores[i] = score;}// 3、遍历数组中的每个数据,找出最大值 最小值 总分// int max = scores[0] , min = scores[0] , sum = 0;int max = scores[0] ;int min = scores[0] ;int sum = 0;for (int i = 0; i < scores.length; i++) {if(scores[i] > max){// 替换最大值变量存储的数据max = scores[i];}if(scores[i] < min){// 替换最小值变量存储的数据min = scores[i];}// 统计总分sum += scores[i];}System.out.println("最高分是:" + max);System.out.println("最低分是:" + min);// 4、统计平均分即可double result = (sum - max - min) * 1.0 / (scores.length - 2);System.out.println("选手最终得分是:" + result);}
}

 如何实现评委打分案例?

定义一个动态初始化的数组用于存储分数数据。定义三个变量用于保存最大值、最小值和总和。遍历数组中的每个元素,依次进行统计。遍历结束后按照规则计算出结果即可。

6.数字加密

需求:

某系统的数字密码,比如 1983 ,采用加密方式进行传输,规则如下:先得到每位数,然后每位数都加上 5 ,  再对 10 求余,最后将所有数字反转,得到一串新数。

               1         9            8             3
+5          6         14         13           8
%10       6         4            3             8
反转       8         3            4             6
加密后的结果就是:8346

 分析

将每位数据存入到数组中去,遍历数组每位数据按照规则进行更改,把更改后的数据从新存入到数组中。 将数组的前后元素进行交换,数组中的最终元素就是加密后的结果。
/**需求:某系统的数字密码,比如1983,采用加密方式进行传输,规则如下:先得到每位数,然后每位数都加上5再对10求余,最后将所有数字反转,得到一串新数。*/
public class Test6 {public static void main(String[] args) {// 1、定义一个数组存储需要加密的数据int[] arr = new int[]{1, 9, 8, 3};// 2、遍历数组中的每个数据,按照规则进行修改for (int i = 0; i < arr.length; i++) {arr[i] = (arr[i] + 5) % 10;}// 3、把数组中的元素进行反转操作。for (int i = 0, j = arr.length - 1; i < j; i++, j--) {// 交换 i 和 j位置处的值,即可反转int temp = arr[j];arr[j] = arr[i];arr[i] = temp;}// 4、遍历数组中的每个元素输出即可for (int i = 0; i < arr.length; i++) {System.out.print(arr[i]);}}
}
定义 2 个变量分别占数组的首尾位置。 一个变量往前走,一个变量往后走,同步交换双方位置处的值。

逆向操作:8346变成1983

public class Test6 {public static void main(String[] args) {// 1、定义一个数组存储需要加密的数据int[] arr = new int[]{8, 3, 4, 6};// 2、把数组中的元素进行反转操作。for (int i = 0, j = arr.length - 1; i < j; i++, j--) {// 交换 i 和 j位置处的值,即可反转int temp = arr[j];arr[j] = arr[i];arr[i] = temp;}// 3、遍历数组中的每个数据,按照规则进行修改for (int i = 0; i < arr.length; i++) {arr[i] = (arr[i] + 5) % 10;}// 4、遍历数组中的每个元素输出即可for (int i = 0; i < arr.length; i++) {System.out.print(arr[i]);}}
}

7.抢红包

需求:

一个大V直播抽奖,奖品是现金红包,分别有{2, 588 , 888, 1000, 10000}五个奖金。请使用代码模拟抽奖,打印出每个奖项,奖项的出现顺序要随机且不重复。打印效果如下:(随机顺序,不一定是下面的顺序)

 

分析

定义一个数组用于存储这些奖金金额。 定义一个数组用于记录已经抽到的金额。

       每次抽奖都随机一个索引,取出索引对应的奖金金额,判断该金额之前是否抽中过,抽中过从新抽一次。 

 

import java.util.Random;
import java.util.Scanner;/**需求:一个大V直播抽奖,奖品是现金红包,分别有{2, 588 , 888, 1000, 10000}五个奖金。请使用代码模拟抽奖,打印出每个奖项,奖项的出现顺序要随机且不重复。打印效果如下:(随机顺序,不一定是下面的顺序)*/
public class Test7 {public static void main(String[] args) {// 1、定义一个数组存储可以抽奖的金额 总数int[] money = {2, 588, 888, 1000, 10000};// 2、定义一个数组用于存储已经被抽中的奖金金额。int[] lockMoney = new int[money.length];// 3、开始模拟抽奖逻辑Scanner sc = new Scanner(System.in);Random r = new Random();for (int i = 0; i < money.length; i++) {// 分别代表抽奖一次。System.out.println("您要开始打开红包吗,您可以输入任意内容进行抽奖:");sc.next(); // 目的是为了让程序在这里等一下,直到用户按了数据和回车就下来抽奖一次!while (true) {// 4、开始抽奖了,随机一个索引取提取金额int index = r.nextInt(money.length);int currentMoney = money[index];boolean flag = true; // 代表默认没有被抽过// 5、判断这个红包金额之前是否有人抽中过!for (int j = 0; j < lockMoney.length; j++) {if(lockMoney[j] == currentMoney){// 说明这个金额已经被抽过了!flag = false; // 表示已经被抽走了break;}}if(flag){System.out.println("您当前很幸运,抽中了:" + currentMoney);// 必须把这个金额放到被抽中的数组中去lockMoney[i] = currentMoney;break; // 当次抽象已经结束!}}}}
}

如何保证每次抽奖的金额不是之前抽过的?

定义一个数组用于记录已经抽到的金额。

每次抽奖都随机一个索引,取出索引对应的奖金金额,判断该金额之前是否在已抽奖金额的数组中。

8.模拟双色球

随机一组中奖的分析:

中奖号码由 6 个红球和 1 个篮球组成 ( 注意: 6 个红球要求不能重复 ) 可以定义方法用于返回一组中奖号码 (7 个数据 ) 返回的形式是一个整型数组。

 

public class Test8 {public static void main(String[] args) {int[] luckNumbers = createLuckNumber();    }public static int[] createLuckNumber(){// a、定义一个动态初始化的数组,存储7个数字int[] numbers = new int[7];  // [12, 23, 0, 0, 0, 0, | 0]//                                   i// b、遍历数组,为每个位置生成对应的号码。(注意:遍历前6个位置,生成6个不重复的红球号码,范围是1-33)Random r = new Random();for (int i = 0; i < numbers.length - 1; i++) {// 为当前位置找出一个不重复的1-33之间的数字while (true) {int data = r.nextInt(33) + 1; // 1-33 ====>  (0-32) + 1// c、注意:必须判断当前随机的这个号码之前是否出现过,出现过要重新随机一个,直到不重复为止,才可以存入数组中去。// 定义一个flag变量,默认认为data是没有重复的boolean flag = true;for (int j = 0; j < i; j++) {if(numbers[j] == data) {// data当前这个数据之前出现过,不能用flag = false;break;}}if(flag) {// data这个数据之前没有出现过,可以使用了numbers[i] = data;break;}}}// d、为第7个位置生成一个1-16的号码作为蓝球号码numbers[numbers.length - 1] = r.nextInt(16) + 1;return numbers;}

保证随机的6个中奖的红球号码不重复的?

        每次随机一个红球号码后去数组中判断是否存在。

        存在需要重新随机一个数字直到不重复为止。

 

用户输入一组双色球号码分析:

定义一个方法,该方法可以录入用户输入的 6 个红球和 1 个篮球号码 该方法最终需要返回一个数组,数组中就是用户录入的号码( 7 位)。
public class Test8 {public static void main(String[] args) {int[] userNumbers = userInputNumbers();public static int[] userInputNumbers(){// a、动态初始化一个数组,长度为7int[] numbers = new int[7];Scanner sc = new Scanner(System.in);for (int i = 0; i < numbers.length - 1; i++) {System.out.println("请您输入第"+(i + 1)+"个红球号码(1-33、不重复):");int data = sc.nextInt();numbers[i] = data;}// b、录入一个蓝球号码System.out.println("请您输入一个蓝球号码(1-16):");int data = sc.nextInt();numbers[numbers.length - 1] = data;return numbers;}
如何去统计红球的命中数量的? 遍历用户的每个选号,然后遍历中奖号码的数组。 看当前选号是否在中奖号码中存在,存在则命中数量加 1

 

中奖情况判断的分析:

定义一个方法,可以接收中奖号码的数组,用户选号的数组。 根据命中红球数和篮球数判断最终的中奖情况并输出详情和中奖金额。
    public static void judge(int[] luckNumbers, int[] userNumbers ){// 判断是否中奖了。// luckNumbers = [12, 23, 8, 16, 15, 32,   9]// userNumbers = [23, 13, 18, 6, 8, 33,   10]// 1、定义2个变量分别存储红球命中的个数,以及蓝球命中的个数。int redHitNumbers = 0;int blueHitNumbers = 0;// 2、判断红球命中了几个,开始统计for (int i = 0; i < userNumbers.length - 1; i++) {for (int j = 0; j < luckNumbers.length - 1; j++) {// 每次找到了相等了,意味着当前号码命中了if(userNumbers[i] == luckNumbers[j]){redHitNumbers ++ ;break;}}}// 蓝球号码是否命中了blueHitNumbers = luckNumbers[6] == userNumbers[6] ? 1 : 0;System.out.println("中奖号码是:"  );printArray(luckNumbers);System.out.println("您投注号码是:"  );printArray(userNumbers);System.out.println("您命中了几个红球:" + redHitNumbers);System.out.println("您是否命中蓝球:" + ( blueHitNumbers == 1 ? "是": "否" ) );// 判断中奖情况了if(blueHitNumbers == 1 && redHitNumbers < 3){System.out.println("恭喜您,中了5元小奖!");}else if(blueHitNumbers == 1 && redHitNumbers == 3|| blueHitNumbers == 0 && redHitNumbers == 4){System.out.println("恭喜您,中了10元小奖!");}else if(blueHitNumbers == 1 && redHitNumbers == 4|| blueHitNumbers == 0 && redHitNumbers == 5){System.out.println("恭喜您,中了200元!");}else if(blueHitNumbers == 1 && redHitNumbers == 5){System.out.println("恭喜您,中了3000元大奖!");}else if(blueHitNumbers == 0 && redHitNumbers == 6){System.out.println("恭喜您,中了500万超级大奖!");}else if(blueHitNumbers == 1 && redHitNumbers == 6){System.out.println("恭喜您,中了1000万巨奖!可以开始享受人生,诗和远方!!");}else {System.out.println("感谢您为福利事业做出的突出贡献!!");}}

 

如何去统计红球的命中数量的? 遍历用户的每个选号,然后遍历中奖号码的数组。 看当前选号是否在中奖号码中存在,存在则命中数量加 1

全部代码如下:

import java.util.Random;
import java.util.Scanner;/**需求:双色球模拟*/
public class Test8 {public static void main(String[] args) {// 1、随机6个红球号码(1-33,不能重复),随机一个蓝球号码(1-16),可以采用数组装起来作为中奖号码int[] luckNumbers = createLuckNumber();// printArray(luckNumbers);// 2、录入用户选中的号码int[] userNumbers = userInputNumbers();// 3、判断中奖情况judge(luckNumbers, userNumbers);}public static void judge(int[] luckNumbers, int[] userNumbers ){// 判断是否中奖了。// luckNumbers = [12, 23, 8, 16, 15, 32,   9]// userNumbers = [23, 13, 18, 6, 8, 33,   10]// 1、定义2个变量分别存储红球命中的个数,以及蓝球命中的个数。int redHitNumbers = 0;int blueHitNumbers = 0;// 2、判断红球命中了几个,开始统计for (int i = 0; i < userNumbers.length - 1; i++) {for (int j = 0; j < luckNumbers.length - 1; j++) {// 每次找到了相等了,意味着当前号码命中了if(userNumbers[i] == luckNumbers[j]){redHitNumbers ++ ;break;}}}// 蓝球号码是否命中了blueHitNumbers = luckNumbers[6] == userNumbers[6] ? 1 : 0;System.out.println("中奖号码是:"  );printArray(luckNumbers);System.out.println("您投注号码是:"  );printArray(userNumbers);System.out.println("您命中了几个红球:" + redHitNumbers);System.out.println("您是否命中蓝球:" + ( blueHitNumbers == 1 ? "是": "否" ) );// 判断中奖情况了if(blueHitNumbers == 1 && redHitNumbers < 3){System.out.println("恭喜您,中了5元小奖!");}else if(blueHitNumbers == 1 && redHitNumbers == 3|| blueHitNumbers == 0 && redHitNumbers == 4){System.out.println("恭喜您,中了10元小奖!");}else if(blueHitNumbers == 1 && redHitNumbers == 4|| blueHitNumbers == 0 && redHitNumbers == 5){System.out.println("恭喜您,中了200元!");}else if(blueHitNumbers == 1 && redHitNumbers == 5){System.out.println("恭喜您,中了3000元大奖!");}else if(blueHitNumbers == 0 && redHitNumbers == 6){System.out.println("恭喜您,中了500万超级大奖!");}else if(blueHitNumbers == 1 && redHitNumbers == 6){System.out.println("恭喜您,中了1000万巨奖!可以开始享受人生,诗和远方!!");}else {System.out.println("感谢您为福利事业做出的突出贡献!!");}}public static int[] userInputNumbers(){// a、动态初始化一个数组,长度为7int[] numbers = new int[7];Scanner sc = new Scanner(System.in);for (int i = 0; i < numbers.length - 1; i++) {System.out.println("请您输入第"+(i + 1)+"个红球号码(1-33、不重复):");int data = sc.nextInt();numbers[i] = data;}// b、录入一个蓝球号码System.out.println("请您输入一个蓝球号码(1-16):");int data = sc.nextInt();numbers[numbers.length - 1] = data;return numbers;}public static void printArray(int[] arr){for (int i = 0; i < arr.length; i++) {System.out.print(arr[i] + " ");}System.out.println();}public static int[] createLuckNumber(){// a、定义一个动态初始化的数组,存储7个数字int[] numbers = new int[7];  // [12, 23, 0, 0, 0, 0, | 0]//                                   i// b、遍历数组,为每个位置生成对应的号码。(注意:遍历前6个位置,生成6个不重复的红球号码,范围是1-33)Random r = new Random();for (int i = 0; i < numbers.length - 1; i++) {// 为当前位置找出一个不重复的1-33之间的数字while (true) {int data = r.nextInt(33) + 1; // 1-33 ====>  (0-32) + 1// c、注意:必须判断当前随机的这个号码之前是否出现过,出现过要重新随机一个,直到不重复为止,才可以存入数组中去。// 定义一个flag变量,默认认为data是没有重复的boolean flag = true;for (int j = 0; j < i; j++) {if(numbers[j] == data) {// data当前这个数据之前出现过,不能用flag = false;break;}}if(flag) {// data这个数据之前没有出现过,可以使用了numbers[i] = data;break;}}}// d、为第7个位置生成一个1-16的号码作为蓝球号码numbers[numbers.length - 1] = r.nextInt(16) + 1;return numbers;}
}

 


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部