活动地址:CSDN21天学习挑战赛
涉及到的知识点:
练习建议:
编程思维和编程能力不是一朝一夕形成的,需要时间的沉淀和大量练习。
具体措施:勤于练习代码,勤于思考,孰能生巧。
前期:先模仿,后期:再创新。
不积跬步,无以至千里;不积小流,无以成江海。
目录
需求:
⚫ 机票价格按照淡季旺季、头等舱和经济舱收费、输入机票原价、月份和头等舱或经济舱。
⚫ 按照如下规则计算机票价格:旺季(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
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
- 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
- b[i]=a[i];
- }
- System.out.println("数组a的内容:");
- for (int i=0;i
- System.out.print(a[i]);
- }
- System.out.println();
- System.out.println("数组b的内容:");
- for (int i=0;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]
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[i]=c[i]-'0';
- n[i]+=5;
- n[i]%=10;
- }
- int []r=new int[n.length];
- for (int i=0;i
- r[i]=n[r.length-1-i];
- }
- System.out.println("加密后的数字:");
- for (int i=0;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
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);
- }
- }
- }
-
相关阅读:
CART决策树的上机实现
react-router-dom6 路由懒加载与组件懒加载
codeforces 1239D-Catowice City(tarjan缩点)
汇编语言中断编程步骤
算法训练.
Consul安装
接口自动化测试用例如何设计,一文搞定!
Net DB Web多级缓存的实现
前端面试宝典
决策式AI与生成式AI
-
原文地址:https://blog.csdn.net/weixin_52473454/article/details/126200493