Java专题训练——21天学习挑战赛


活动地址:CSDN21天学习挑战赛

涉及到的知识点:

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

 练习建议:

编程思维和编程能力不是一朝一夕形成的,需要时间的沉淀和大量练习。

具体措施:勤于练习代码,勤于思考,孰能生巧。

前期:先模仿,后期:再创新。

不积跬步,无以至千里;不积小流,无以成江海。

目录

 ➢ 案例一:买飞机票

➢ 案例二:找素数

➢ 案例三:开发验证码

➢ 案例四:数组元素的复制

➢ 案例五:评委打分

➢ 案例六:数字加密

➢ 案例七:模拟双色球[拓展]


 

 ➢ 案例一:买飞机票

需求:

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

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

分析:

⚫ 键盘录入机票原价、月份和机舱类型。

⚫ 使用if判断月份是是旺季还是淡季,使用switch分支判断是头等舱还是经济舱。

⚫ 选择对应的折扣进行计算结果

import java.util.Scanner;

public class chapter01 {
    public static void main(String[] args) {
        double PrimeCost;
        int Month ;
        String Type;
        Scanner scanner=new Scanner(System.in);
        System.out.println("请输入原价:");
        PrimeCost=scanner.nextDouble();
        System.out.println("请输入月份:");
        Month=scanner.nextInt();
        System.out.println("请输入机舱类型:");
        Type=scanner.next();
        if(Month>=5&&Month<=10){//旺季
            switch (Type){
                case "头等舱":PrimeCost*=0.9;
                    break;
                case "经济舱":PrimeCost*=0.85;
                    break;
            }
        }else {//淡季
            switch (Type){
                case "头等舱":PrimeCost*=0.7;
                    break;
                case "经济舱":PrimeCost*=0.65;
                    break;
            }
        }
        System.out.println("最终的价格为"+PrimeCost);
    }
}

➢ 案例二:找素数

需求:

⚫ 判断101到200之间有多少素数,并将它们输出

分析 :

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

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

public class chapter02 {
    public static boolean Pd(int num){
        if(num==1||num==2)return true;//1和2是素数
        for (int i=2;i<num/2;i++){//从2开始遍历到该数的一半的数据,看是否有数据可以整除它,有则不是素数,没有则是素数。
            if(num%i==0)return false;
        }
        return true;
    }
    public static void main(String[] args) {
        int index=101;
        int sum=0;
        for (int i=index;i<=200;i++){
            if(Pd(i)){
                System.out.println(i);
                sum++;
            }
        }
        System.out.println("一共"+sum+"个素数");
    }
}

➢ 案例三:开发验证码

需求:

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

分析:

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

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

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

import java.util.Random;

public class chapter03 {
    public static String QueRen(int count){
        String str="";
        char yan[]=new char[count];
        for (int i=0;i<count;i++){
            char c;
            Random random=new Random();
            int type=random.nextInt(3);
            if (type==1){
                int num=random.nextInt(9);
                c=String.valueOf(num).charAt(0);
            }else if(type==2){
                int num=random.nextInt(24);
                c= (char) ('A'+num);
            }else {
                int num=random.nextInt(24);
                c= (char) ('a'+num);
            }
            yan[i]=c;
        }
        str=new String(yan);
        return str;
    }
    public static void main(String[] args) {
        System.out.println("验证码为:"+QueRen(5));
    }
}

➢ 案例四:数组元素的复制

 需求:

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

分析:

⚫ 需要动态初始化一个数组,长度与原数组一样。

⚫ 遍历原数组的每个元素,依次赋值给新数组。

⚫ 输出两个数组的内容

public class chapter04 {
    public static void main(String[] args) {
        int a[]={1,3,2,4,5,6};
        int length=a.length;
        int b[]=new int[length];
        for (int i=0;i<length;i++){
            b[i]=a[i];
        }
        System.out.println("数组a的内容:");
        for (int i=0;i<length;i++){
            System.out.print(a[i]);
        }
        System.out.println();
        System.out.println("数组b的内容:");
        for (int i=0;i<length;i++){
            System.out.print(b[i]);
        }
    }
}

➢ 案例五:评委打分

需求 :

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

分析:

⚫ 把6个评委的分数录入到程序中去 

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

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

import java.util.Scanner;

public class chapter05 {
    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
        int[] cheng=new int[6];
        for (int i=0;i<6;i++) cheng[i]=scanner.nextInt();
        int max=0;
        int min=0;
        for (int i=0;i<6;i++){//找到最高分和最低分的下标
            if(cheng[max]<cheng[i])max=i;
            if(cheng[min]>cheng[i])min=i;
        }
        int sum=0;
        for (int i=0;i<6;i++){
            sum+=cheng[i];
        }
        sum-=cheng[max];
        sum-=cheng[min];
        System.out.println("成绩为:"+sum/4);
    }
}

➢ 案例六:数字加密

需求:

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

分析 :

⚫ 将每位数据存入到数组中去,遍历数组每位数据按照规则进行更改,把更改后的数据从新存入到数组中。

⚫ 将数组的前后元素进行交换,数组中的最终元素就是加密后的结果。


import java.util.Scanner;

public class chapter06 {
    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
        System.out.println("请输入需要加密的数:");
        int num=scanner.nextInt();
        String str=String.valueOf(num);
        char []c=str.toCharArray();
        int []n=new int[c.length];
        for (int i=0;i<n.length;i++){
            n[i]=c[i]-'0';
            n[i]+=5;
            n[i]%=10;
        }
        int []r=new int[n.length];
        for (int i=0;i<r.length;i++){
            r[i]=n[r.length-1-i];
        }
        System.out.println("加密后的数字:");
        for (int i=0;i<r.length;i++){
            System.out.print(r[i]);
        }
    }
}

➢ 案例七:模拟双色球[拓展]

需求:

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

分析 :

⚫ 定义一个集合用于存储这些奖金金额。

⚫ 每次抽奖都随机一个索引,取出索引对应的奖金金额。

import java.util.ArrayList;
import java.util.List;
import java.util.Random;

public class chapter07 {
    public static void main(String[] args) {
        Random random=new Random();
        List<Integer>list=new ArrayList<>();
        list.add(22);
        list.add(588);
        list.add(888);
        list.add(1000);
        list.add(10000);
        for (int i=0;i<5;i++){
            int index=random.nextInt(list.size());
            System.out.println("第"+(i+1)+"抽到的是"+list.get(index));
            list.remove(index);
        }
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

无忧#

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值