day06-编程思维和编程能力、综合应用专题课

专题课(综合案例)

请添加图片描述
请添加图片描述
案例一:买飞机票
请添加图片描述

package com.itheima;

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;
    }
}

请添加图片描述
案例二:找素数
请添加图片描述

package com.itheima;
/**
    需求:找出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");
            }
        }
    }
}

请添加图片描述
案例三:开发验证码
请添加图片描述

package com.itheima;

import java.util.Random;

/**
      需求:定义方法实现随机产生一个5位的验证码,每位可能是数字、大写字母、小写字母。
 */
public class Test3 {
    public static void main(String[] args) {
        // 4、调用获取验证码的方法得到一个随机的验证码
        String code = createCode(8);
        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  2
            switch (type){
                case 0:
                    // 大写字符(A 65 - Z 65+25)  (0 - 25) + 65
                    char ch = (char) (r.nextInt(26) + 65);
                    code += ch;
                    break;
                case 1:
                    // 小写字符(a 97 - z 97+25)  (0 - 25) + 97
                    char ch1 = (char) (r.nextInt(26) + 97);
                    code += ch1;
                    break;
                case 2:
                    // 数字字符
                    code += r.nextInt(10); // 0 - 9
                    break;
            }
        }
        return code;
    }
}

请添加图片描述
案例四:数组元素的复制
请添加图片描述

package com.itheima;

/**
    需求:把一个数组中的元素复制到另一个新数组中去。
 */
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];
        }
    }
}

请添加图片描述
案例五:评委打分请添加图片描述

package com.itheima;

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);
    }
}

请添加图片描述

案例六:数字加密
请添加图片描述
请添加图片描述

package com.itheima;

/**
     需求:某系统的数字密码,比如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]);
        }
    }
}

请添加图片描述
请添加图片描述

package com.itheima;

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; // 当次抽象已经结束!
                }
            }
        }
    }
}

请添加图片描述
案例七:模拟双色球[拓展案例]
◼ 业务分析、随机生成一组中奖号码请添加图片描述
请添加图片描述
◼ 用户输入一组双色球号码请添加图片描述请添加图片描述

◼ 判断中奖情况
请添加图片描述

请添加图片描述

package com.itheima;

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、动态初始化一个数组,长度为7
        int[] 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;
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值