猿创征文 | Java知识【综合练习】一
【摘要】
目录
练习一:飞机票
练习二:打印素数
练习三:生成验证码
练习四:复制数组
练习五:评委打分
练习一:飞机票
需求:
机票价格按照淡季旺季、头等舱和经济舱收费、输入机票原价、月份和头等舱或经济舱。
按照如下规则计算机票价格:旺季(5-10月)头等舱9折,经济舱8.5折,淡季(11月到来年4月)头等舱7折,经济舱...
目录
练习一:飞机票
需求:
机票价格按照淡季旺季、头等舱和经济舱收费、输入机票原价、月份和头等舱或经济舱。
按照如下规则计算机票价格:旺季(5-10月)头等舱9折,经济舱8.5折,淡季(11月到来年4月)头等舱7折,经济舱6.5折。
代码示例:
-
public class Test1 {
-
public static void main(String[] args) {
-
/* 机票价格按照淡季旺季、头等舱和经济舱收费、输入机票原价、月份和头等舱或经济舱。
-
按照如下规则计算机票价格:旺季(5-10月)头等舱9折,经济舱8.5折,淡季(11月到来年4月)头等舱7折,经济舱6.5折。*/
-
-
//分析:
-
//1.键盘录入机票原价、月份、头等舱或经济舱
-
Scanner sc = new Scanner(System.in);
-
System.out.println("请输入机票的原价");
-
int ticket = sc.nextInt();
-
System.out.println("请输入当前的月份");
-
int month = sc.nextInt();
-
System.out.println("请输入当前购买的舱位 0 头等舱 1 经济舱");
-
int seat = sc.nextInt();
-
//2.先判断月份是旺季还是淡季
-
//ctrl + alt + M 自动抽取方法
-
if (month >= 5 && month <= 10) {
-
//旺季 //3.继续判断当前机票是经济舱还是头等舱
-
//ticket = getPrice(ticket, seat, 0.9, 0.85);
-
ticket = getTicket(ticket, seat, 0.9, 0.85);
-
} else if ((month >= 1 && month <= 4) || (month >= 11 && month <= 12)) {
-
//淡季
-
//ticket = getPrice(ticket, seat, 0.7, 0.65);
-
ticket = getTicket(ticket, seat, 0.7, 0.65);
-
} else {
-
//表示键盘录入的月份是一个非法数据
-
System.out.println("键盘录入的月份不合法");
-
}
-
-
System.out.println(ticket);
-
}
-
-
public static int getTicket(int ticket, int seat, double v, double v2) {
-
if (seat == 0) {
-
//头等舱
-
ticket = (int) (ticket * v);
-
} else if (seat == 1) {
-
//经济舱
-
ticket = (int) (ticket * v2);
-
} else {
-
System.out.println("没有这个舱位");
-
}
-
return ticket;
-
}
-
-
//1.我要干嘛?根据舱位和折扣来计算最终的票价
-
//2.我干这件事,需要什么才能完成?原价 舱位 头等舱的折扣 经济舱的折扣
-
//3.方法的调用处是否需要继续使用这个结果 需要
-
/* public static int getPrice(int ticket, int seat, double v0, double v1) {
-
if (seat == 0) {
-
//头等舱
-
ticket = (int) (ticket * v0);
-
} else if (seat == 1) {
-
//经济舱
-
ticket = (int) (ticket * v1);
-
} else {
-
System.out.println("没有这个舱位");
-
}
-
return ticket;
-
}*/
-
}
练习二:打印素数
判断101~200之间有多少个素数,并输出所有素数。
备注:素数就是质数
代码示例:
-
public class Test2 {
-
public static void main(String[] args) {
-
//判断 101 ~ 200 之间有多少个素数,并打印所有素数
-
-
//思路一: 2 ~ 99
-
//定义变量i ,赋值100
-
//判断i是否为质数
-
-
//定义一个变量用来统计有多少个质数
-
int count = 0;
-
//外循环:遍历101~200这个范围,依次得到这个范围之内的每一个数字
-
for (int i = 101; i <= 200; i++) {
-
//i 依次表示循环中的每一个数字
-
//继续判断i是否为一个质数
-
boolean flag = true;
-
//内循环:判断当前数字是否为一个质数。
-
for (int j = 2; j < i; j++) {
-
//j 表示2~99之间的每一个数字
-
if(i % j == 0){
-
flag = false;
-
//跳出单层循环,内循环
-
break;
-
}
-
}
-
if(flag){
-
System.out.println("当前数字"+i+"是质数");
-
count++;
-
}
-
}
-
-
System.out.println("一共有" + count + "个质数");
-
-
/* int i = 7;
-
boolean flag = true;
-
for (int j = 2; j < i; j++) {
-
//j 表示2~99之间的每一个数字
-
if(i % j == 0){
-
flag = false;
-
break;
-
}
-
}
-
if(flag){
-
System.out.println("当前数字是质数");
-
}else{
-
System.out.println("当前数字不是一个质数");
-
}*/
-
}
-
}
练习三:生成验证码
需求:
定义方法实现随机产生一个5位的验证码
验证码格式:
长度为5
前四位是大写字母或者小写字母
最后一位是数字
代码示例:
-
public class Test3 {
-
public static void main(String[] args) {
-
/* 需求:
-
定义方法实现随机产生一个5位的验证码
-
验证码格式:
-
长度为5
-
前四位是大写字母或者小写字母
-
最后一位是数字
-
*/
-
-
//方法:
-
//在以后如果我们要在一堆没有什么规律的数据中随机抽取
-
//可以先把这些数据放到数组当中
-
//再随机抽取一个索引
-
-
//分析:
-
//1.大写字母和小写字母都放到数组当中
-
char[] chs = new char[52];
-
for (int i = 0; i < chs.length; i++) {
-
//ASCII码表
-
if(i <= 25){
-
//添加小写字母
-
chs[i] = (char)(97 + i);
-
}else{//27
-
//添加大写字母
-
// A --- 65
-
chs[i] = (char)(65 + i - 26);
-
}
-
}
-
-
//定义一个字符串类型的变量,用来记录最终的结果
-
String result = "";
-
-
//2.随机抽取4次
-
//随机抽取数组中的索引
-
Random r = new Random();
-
for (int i = 0; i < 4; i++) {
-
int randomIndex = r.nextInt(chs.length);
-
//利用随机索引,获取对应的元素
-
//System.out.println(chs[randomIndex]);
-
result = result + chs[randomIndex];
-
}
-
//System.out.println(result);
-
//3.随机抽取一个数字0~9
-
int number = r.nextInt(10);
-
//生成最终的结果
-
result = result + number;
-
-
//打印最终结果
-
System.out.println(result);
-
-
}
-
}
练习四:复制数组
需求:
把一个数组中的元素复制到另一个新数组中去。
代码示例:
-
public class Test4 {
-
public static void main(String[] args) {
-
/* 需求:
-
把一个数组中的元素复制到另一个新数组中去。*/
-
-
//分析:
-
//1.定义一个老数组并存储一些元素
-
int[] arr = {1,2,3,4,5};
-
//2.定义一个新数组的长度跟老数组一致
-
int[] newArr = new int[arr.length];
-
//3.遍历老数组,得到老数组中的每一个元素,依次存入到新数组当中
-
for (int i = 0; i < arr.length; i++) {
-
//i 表示老数组中的索引。新数组中的每一个索引
-
//arr[i] 表示老数组中的元素
-
newArr[i] = arr[i];
-
}
-
-
//4.新数组中已经存满元素了
-
for (int i = 0; i < newArr.length; i++) {
-
System.out.println(newArr[i]);
-
}
-
-
}
-
}
练习五:评委打分
需求 :
在唱歌比赛中,有6名评委给选手打分,分数范围是[0 - 100]之间的整数。选手的最后得分为:去掉最高分、最低分后的4个评委的平均分,请完成上述过程并计算出选手的得分。
代码示例:
-
public class Test5 {
-
public static void main(String[] args) {
-
//在唱歌比赛中,有6名评委给选手打分,分数范围是[0 - 100]之间的整数。
-
// 选手的最后得分为:去掉最高分、最低分后的4个评委的平均分,请完成上述过程并计算出选手的得分。
-
-
-
//分析:
-
//1.定义一个数组,用来存储6名评委的打分(0~100)
-
int[] scoreArr = getScores();
-
for (int i = 0; i < scoreArr.length; i++) {
-
System.out.println(scoreArr[i]);
-
}
-
//2.求出数组中的最大值
-
int max = getMax(scoreArr);
-
//3.求出数组中的最小值
-
int min = getMin(scoreArr);
-
//4.求出数组中6个分数的总和
-
int sum = getSum(scoreArr);
-
//5.(总和 - 最大值 - 最小值 )/4
-
int avg = (sum - max - min)/(scoreArr.length - 2);
-
//6.打印结果
-
System.out.println("选手的最终得分为:" + avg);
-
}
-
-
-
public static int getSum(int[] scoreArr){
-
int sum = 0;
-
for (int i = 0; i < scoreArr.length; i++) {
-
sum = sum + scoreArr[i];
-
}
-
return sum;
-
-
}
-
-
-
-
//求数组的最大值
-
public static int getMax(int[] scoreArr){
-
int max = scoreArr[0];
-
for (int i = 1; i < scoreArr.length; i++) {
-
if(scoreArr[i] > max){
-
max = scoreArr[i];
-
}
-
}
-
return max;
-
}
-
-
//求数组的最小值
-
public static int getMin(int[] scoreArr){
-
int min = scoreArr[0];
-
for (int i = 1; i < scoreArr.length; i++) {
-
if(scoreArr[i] < min){
-
min = scoreArr[i];
-
}
-
}
-
return min;
-
}
-
-
-
-
//1.我要干嘛?定义一个数组,用来存储6名评委的打分(0~100)
-
//2.我需要什么?都不需要
-
//3.干完了这件事情,是否需要返回?必须返回
-
public static int[] getScores(){
-
//定义数组
-
int[] scores = new int[6];
-
//使用键盘录入的形式,输入分数:0~100
-
Scanner sc = new Scanner(System.in);
-
for (int i = 0; i < scores.length; ) {
-
System.out.println("请输入评委的打分");
-
int score = sc.nextInt();//100
-
if(score >=0 && score<= 100){
-
scores[i] = score;
-
i++;
-
}else{
-
System.out.println("成绩超出了范围,继续录入,当前的i为:" + i);
-
}
-
}
-
return scores;
-
}
-
}
文章来源: qianxu.blog.csdn.net,作者:爱吃豆的土豆,版权归原作者所有,如需转载,请联系作者。
原文链接:qianxu.blog.csdn.net/article/details/126903114
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)