Java(六)综合练习

练习一:飞机票

题目描述

机票价格按照淡季旺季、头等舱和经济舱收费、输入机票原价、月份和头等舱或经济舱。 按照如下规则计算机票价格:

  • 旺季(5-10月)头等舱9折,经济舱8.5折

  • 淡季(11月到来年4月)头等舱7折,经济舱6.5折

代码

import java.util.Scanner;
​
public class Test1 {
    public static void main(String[] args) {
        // 键盘录入机票原价、月份、头等舱或经济舱
        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();
​
        // 判断月份是旺季还是淡季
        if (month >= 5 && month <= 10) {
            // 旺季
            ticket = getTicket(ticket, seat, 0.9, 0.85);
        } else if ((month >= 1 && month <= 4) || (month >= 11 && month <= 12)) {
            // 淡季
            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;
    }
​
}

练习二:打印素数

题目描述

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

代码

import java.lang.Math;
​
public class Test2 {
    public static void main(String[] args) {
        int count = 0;
​
        for (int i = 101; i <= 200; i++) {
            boolean flag = true;
            for (int j = 2; j <= Math.sqrt(i); j++) {
                if (i % j == 0) {
                    flag = false;
                    break;
                }
            }
            if (flag) {
                System.out.println(i + "is prime.");
                count++;
            }
        }
​
        System.out.println("在101到200之间共有" + count + "个质数");
​
​
    }
}

练习三:验证码

题目描述

定义方法实现随机产生一个5位的验证码 验证码格式:

  • 长度为5

  • 前四位是大写字母或者小写字母

  • 最后一位是数字

代码

import java.util.Random;
​
public class Test3 {
    public static void main(String[] args) {
        char[] chs = new char[52];
        for (int i = 0; i < chs.length; i++) {
            if (i <= 25) {
                // 存放小写字母
                chs[i] = (char) (97 + i);
            } else {
                // 存放大写字母
                chs[i] = (char) (65 + i - 26);
            }
        }
​
        String result = "";
​
        Random r = new Random();
        for (int i = 0; i < 4; i++) {
            int randomIndex = r.nextInt(chs.length);
            // 利用随机索引,获取对应的元素
            result = result + chs[randomIndex];
        }
​
        int number = r.nextInt(10);
​
        result = result + number;
​
        System.out.println(result);
​
    }
}

练习四:复制数组

题目描述

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

代码

public class Test4 {
    public static void main(String[] args) {
        // 定义数组
        int[] arr = {1, 2, 3, 4, 5};
​
        // 定义一个新数组
        int[] newArr = new int[arr.length];
​
        // 遍历数组
        for (int i = 0; i < arr.length; i++) {
            newArr[i] = arr[i];
        }
​
        for (int i = 0; i < newArr.length; i++) {
            System.out.println(newArr[i]);
        }
​
    }
}

练习五:评委打分

题目描述

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

代码

import java.util.Scanner;
​
public class Test5 {
    public static void main(String[] args) {
        // 定义一个数组,用来存储6名评委的打分(0~100)
        int[] scoreArr = getScores();
        for (int i = 0; i < scoreArr.length; i++) {
            System.out.println(scoreArr[i]);
        }
​
        // 求出数组中的最大值
        int max = getMax(scoreArr);
        // 求出数组中的最小值
        int min = getMin(scoreArr);
        // 求出数组中6个分数的总和
        int sum = getSum(scoreArr);
        // (总和 - 最大值 - 最小值) / 4
        int avg = (sum - max - min) / (scoreArr.length - 2);
​
        System.out.println("选手的最终得分为:" + avg);
    }
​
    public static int getSum(int[] scoreArr) {
        int sum = 0;
        for (int i = 0; i < scoreArr.length; i++) {
            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;
    }
​
    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;
            } else {
                System.out.println("成绩超出了范围,继续录入,当前的i为:" + i);
            }
        }
        return scores;
    }
​
}

练习六:数字加密

题目描述

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

例如:

1 9 8 3

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

代码

public class Test6_1 {
    public static void main(String[] args) {
        // 把整数里面的每一位放到数组当中
        int[] arr = {1, 9, 8, 3};
        
        // 加密
        for (int i = 0; i < arr.length; i++) {
            arr[i] = (arr[i] + 5) % 10;
        }
        for (int i = 0, j = arr.length - 1; i < j; i++, j--) {
            int temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
        }
        
        int number = 0;
        for (int i = 0; i < arr.length; i++) {
            number = number * 10 + arr[i];
        }
        System.out.println(number);
    }
}

练习七:数字解密

题目描述

把上一题加密之后的数据进行解密

代码

public class Test8 {
    public static void main(String[] args) {
        int[] arr = {8, 3, 4, 6};
        
        // 反转
        for (int i = 0, j = arr.length - 1; i < j; i++, j--) {
            int temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
        }
        
        // 现在0-4之间的数字都是由原本5-9之间的数字+5加密-10得到的
        // 现在5-9之间的数字都是由原本0-4之间的数字+5得到的
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] >= 0 && arr[i] <= 4) {
                arr[i] = arr[i] + 10;
            }
        }
        for (int i = 0; i < arr.length; i++) {
            arr[i] = arr[i] - 5;
        }
​
        int number = 0;
        for (int i = 0; i < arr.length; i++) {
            number = number * 10 + arr[i];
        }
        System.out.println(number);
    }
    
}

练习八:抽奖

题目描述

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

解法一代码

import java.util.Random;
​
public class Test9 {
    public static void main(String[] args) {
        int[] arr = {2, 588, 888, 1000, 10000};
        int[] newArr = new int[arr.length];
​
        Random r = new Random();
        for (int i = 0; i < 5; ) {
            // 获取随机索引
            int randomIndex = r.nextInt(arr.length);
            // 获取奖项
            int prize = arr[randomIndex];
            // 判断当前的奖项是否存在,如果存在则重新抽取,如果不存在,就表示是有效奖项
            boolean flag = contains(newArr, prize);
            if(!flag){
                newArr[i] = prize;
                i++;
            }
        }
​
        for (int i = 0; i < newArr.length; i++) {
            System.out.println(newArr[i]);
        }
​
​
    }
​
    // 判断prize在数组当中是否存在
    public static boolean contains(int[] arr,int prize){
        for (int i = 0; i < arr.length; i++) {
            if(arr[i] == prize){
                return true;
            }
        }
        return false;
    }
​
​
}

解法二代码

import java.util.Random;
​
public class Test10 {
    public static void main(String[] args) {
        int[] arr = {2, 588, 888, 1000, 10000};
        Random r = new Random();
        
        for (int i = 0; i < arr.length; i++) {
            // 获取随机索引
            int randomIndex = r.nextInt(arr.length);
            // 拿着i跟随机索引randomIndex上的值进行交换
            int temp = arr[i];
            arr[i] = arr[randomIndex];
            arr[randomIndex] = temp;
        }
​
        for (int i = 0; i < arr.length; i++) {
            System.out.println(arr[i]);
        }
​
    }
    
}

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值