【JAVA基础】专题课(综合案例)

83 阅读5分钟

开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第5天,点击查看活动详情

目的

复习前半段课程学习的Java编程知识,能够使用所学的知识解决问题,提升同学们的编程能力。

涉及到的知识点

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

🍊案例1.买飞机票

需求:

机票价格按照淡季旺季、头等舱和经济舱收费、输入机票原价、月份和头等舱或经济舱。

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

import java.util.Scanner;

/**
 * 机票价格按照淡季旺季、头等舱和经济舱收费、输入机票原价、月份和头等舱或经济舱。
 * 按照如下规则计算机票价格:旺季(5-10月)头等舱9折,经济舱8.5折,淡季(11月到来年4月)头等舱7折,经济舱6.5折。
 */
public class base {
    public static void main(String[] args) {
        boolean flag=true;
        Scanner scanner = new Scanner(System.in);
        while (flag){
            System.out.println("请输入机票原价");
            int money = scanner.nextInt();
            System.out.println("请输入月份");
            int month = scanner.nextInt();
            System.out.println("请输入头等舱(1)或经济舱(2)");
            int j = scanner.nextInt();
            double Money=compare(money, month, j);
            flag=false;
            
            if (Money==-1){
                flag=true;
                continue;
            }
            System.out.println("价格:"+Money);


        }



    }

    private static double compare(int money,int month,int k) {
        if (month>=5&&month<=10){//旺季
            if (k==1){
                return  0.9*money;
            }else {
                return 0.85*money;
            }
        }else if (month==11||month==12||month>=1&&month<=4){//淡季
            if (k==1){
                return  0.7*money;
            }else {
                return 0.65*money;
            }

        }
        else {
            System.out.println("你输入的月份错误");
            return -1;
        }


    }


}

🍓案例2.找素数

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

说明

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

分析

  • 101-200之间的数据可以采用循环依次拿到; 每拿到一个数,判断该数是否是素数。
  • 判断规则是:从2开始遍历到该数的一半的数据,看是否有数据可以整除它,有则不是素数,没有则是素数。
/**
 * 判断101-200之间有多少个素数,并输出所有素数。
 * 说明
 * 素数:如果除了1和它本身以外,不能被其他正整数整除,就叫素数。
 */
public class base {
    public static void main(String[] args) {
        for (int i = 101; i <= 200; i++) {
            boolean flag=true;

            for (int j = 2; j <(i/2); j++) {
                if (i%j==0){
                    flag=false;
                    break;

                }
            }
            if (flag){
                System.out.print(i+" ");
            }

        }



    }



}

🍍案例3.开发验证码

需求:

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

分析:

① 定义一个方法,生成验证码返回:方法参数是位数、方法的返回值类型是String。

② 在方法内部使用for循环生成指定位数的随机字符,并连接起来。

③ 把连接好的随机字符作为一组验证码进行返回。

import java.util.Random;
/**
 * 需求:
 * 定义方法实现随机产生一个5位的验证码,每位可能是数字、大写字母、小写字母。
 */
public class base {
    public static void main(String[] args) {
        System.out.println(verification(5));
    }

    private static String verification(int n) {
        Random random = new Random();
        String code="";
        for (int i = 0; i < n; i++) {
            int type=random.nextInt(3);// 0 1 2
            switch(type){
                case 0://大写字母
                    char ch=(char) (random.nextInt(26)+65);
                    code+=ch;
                    break;
                case 1://小写字母
                    char ch1=(char) (random.nextInt(26)+97);
                    code+=ch1;
                    break;
                case 2://数字
                    code+= random.nextInt(10);
                    break;
            }
        }

return code;

    }


}

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

① 定义一个String类型的变量存储验证码字符。

② 定义一个for循环,循环5次。

③ 随机生成0|1|2的数据,依次代表当前位置要生成数字|大写字母|小写字母。

④ 把0、1、2交给switch生成对应类型的随机字符,把字符交给String变量。

⑤ 循环结束后,返回String类型的变量即是所求的验证码结果。

​🥭案例4.数组元素复制 ​

需求:

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

分析:

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

import java.util.Random;
/**
 * 需求:
 * 把一个数组中的元素复制到另一个新数组中去。
 */
public class base {
    public static void main(String[] args) {
        int arr[]={1,2,3,4,5};
        int arr2[]=new int[arr.length];
        copy(arr,arr2);
        printf(arr2);
        System.out.println();
        printf(arr);





    }

    private static void printf(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.print("]");
    }

    private static void copy(int[] arr,int[] arr2) {
        for (int i = 0; i < arr.length; i++) {
            arr2[i]=arr[i];
        }


    }


}

🥝案例5.评委打分案例

需求 :

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

分析:

① 把6个评委的分数录入到程序中去 ----> 使用数组

② 遍历数组中每个数据,进行累加求和,并找出最高分、最低分。

③ 按照分数的计算规则算出平均分。

import java.util.Random;
import java.util.Scanner;

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

 * 分析:
 * ① 把6个评委的分数录入到程序中去 ----> 使用数组
 * ② 遍历数组中每个数据,进行累加求和,并找出最高分、最低分。
 * ③ 按照分数的计算规则算出平均分。
 */
public class base {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);

        int arr[]=new int[6];
        System.out.println("请输入评委打的分数");
        for (int i = 0; i < arr.length; i++) {
            arr[i]=scanner.nextInt();
        }


        System.out.println("平均分:"+(sum(arr) - Min(arr) - Max(arr))*1.0/4);


    }

    private static int Max(int[] arr) {
        int max=arr[0];
        for (int i = 1; i < arr.length ; i++) {
            if (arr[i]>max){
                max=arr[i];
            }
        }
        return max;

    }

    private static int Min(int[] arr) {
        int min=arr[0];
        for (int i = 1; i < arr.length ; i++) {
            if (arr[i]<min){
                min=arr[i];
            }
        }
        return min;
    }


    private static int sum(int[] arr) {
        int sum=0;
        for (int i = 0; i < arr.length; i++) {
            sum+=arr[i];
        }
        return sum;


    }


}

🥦案例6.数字加密

需求:

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

分析

  • 将每位数据存入到数组中去,遍历数组每位数据按照规则进行更改,把更改后的数据从新存入到数组中。
  • 将数组的前后元素进行交换,数组中的最终元素就是加密后的结果。
import java.util.Arrays;

import java.util.Scanner;

/**
 * 需求:
 * 某系统的数字密码,比如1983,采用加密方式进行传输,规则如下:先得到每位数,然后每位数都加上5 , 再对10求余,最后将所有数字反转,得到一串新数。
 */
public class base {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入密码的位数");
        int i = scanner.nextInt();
        int arr[]=new int[i];

        for (int j = 0; j < arr.length; j++) {
            System.out.println("请输入第"+(j+1)+"个数字");
            arr[j]=scanner.nextInt();
        }
        //输出数组元素
        System.out.println("未加密前:"+Arrays.toString(arr));//API 后期会讲
        encryption(arr);

        System.out.println("加密后:"+Arrays.toString(arr));

    }

    private static void encryption(int[] arr) {
        for (int i = 0; i < arr.length; i++) {
            arr[i]+=5;
            arr[i]%=10;
        }
        int temp=0;
        int end= arr.length-1;

        for (int i = 0; i < (arr.length/2); i++,end--) {
            temp=arr[i];
           arr[i] =arr[end];
           arr[end]=temp;

        }

    }


}