Java实验案例(一)

目录

案例一:买飞机票

案例二:开发验证码

案例三:评委打分

案例四:数字加密

案例五:数组拷贝

案例六:抢红包

案例七:找素数的三种方法

案例八:打印乘法口诀表

案例九:打印三角形

案例十:模拟双色球


案例一:买飞机票

我的思考:

 用 if 语句分割开淡旺季,再分别在淡旺季中区分两种舱的价格。

我的初步代码:

 逻辑非常简单,没有问题,但是感觉代码写的冗余不清晰,明明非常简单的几步感觉被复杂化了,所以写代码必须简洁明了,简单易懂。

尤其时main函数主体内的代码要少,几行之内搞定是最好的,可以将繁冗的代码封装成方法,减少main函数中的代码:

案例二:开发验证码

 

我的思考:

首先,生成的验证码位数是需要我们输入确定的。每一位可以用一个字符表示(数字就是数字字符 '0' ~ '9'),可以用随机数确定每一位是数字字符还是大小写字母。

每一位可以通过字符串拼接的方式 ' + ' 来实现单个字符变成字符串。

数字字符容易用随机数生成,大小写字母其实就是ASCLL码,也可以通过随机数生成。

我的代码:

案例三:评委打分

 

案例四:数字加密

我的思考:

首先输入的是字符串,在字符串中改变每一位数字并不方便,于是我设置了一个字符数组接收字符串,对每一位的数字进行算术运算字符并不好处理,于是我设置了一个整型临时变量,循环地处理每一位的算术运算,再将算好的整型数字转化成字符放到字符数组中去。返回数组的地址,在main函数中用一个字符串接收,最后打印出来。

我的代码: 

public class test_01 {public static void main(String[] args) {Scanner sc = new Scanner(System.in);System.out.println("请输入原始密码:");String ori_code = sc.next();String codes = new String(encryption(ori_code));System.out.println("加密后的密码是:" + codes);}public static char[] encryption(String ori_code){assert(ori_code != null);char[] code = new char[ori_code.length()];for (int i = 0; i < code.length; i++) {int temp = 0;temp = ori_code.charAt(i)-'0';temp += 5;temp %= 10;code[i] = (char)(temp+'0');}for(int i = 0,j = ori_code.length()-1;i < j;i++,j--){char tmp = code[i];code[i] = code[j];code[j] = tmp;}return code;}
}

案例五:数组拷贝

 我的思考:

复制一个内容一样的数组很容易,关键在于这题需要的是一模一样的数组,那也就是说连地址都相同,所以需要把旧数组的地址赋给新数组。

我的代码:

public class test_01 {public static void main(String[] args) {int[] arr = {11,22,33};System.out.println(Arrays.toString(copy(arr)));}public static int[] copy(int[] arr){int[] copy_arr = new int[arr.length];copy_arr = arr;for (int i = 0; i < arr.length; i++) {copy_arr[i] = arr[i];}System.out.println(copy_arr);System.out.println(arr);return copy_arr;}
}

 

案例六:抢红包

我的思考:

一共有五个数据,可以存放在整型数组中,用switch语句分别处理每种抽到的情况,用随机数控制switch语句的执行。

关键在于每个数只能抽到一次,可以在循环中处理重复情况。(我没想到简便的处理方法,就是很僵硬地设置了5个计数器分别对应5种抽奖结果,抽到过地break)

我的代码:

public class test_01 {public static void main(String[] args) {int[] arr = {9,666,188,520,99999};extractRedEnvelopes(arr);}public static void extractRedEnvelopes(int[] arr){System.out.println("有五个红包,分别是9,666,188,520,99999的");System.out.println("现在开始直播抽取红包");Random r = new Random();int count1 = 0,count2 = 0,count3 = 0,count4 = 0,count5 = 0;while(count1 + count2 + count3 + count4 + count5 != 5){System.out.println("请按任意键开始抽奖");Scanner sc = new Scanner(System.in);String s = sc.next();if (s.equals("1")) {int random = r.nextInt(5); //0~4switch (random) {case 0:if (count1 == 1){System.out.println("很抱歉,你没抽到");break;}System.out.println("恭喜你,你抽到了," + 6);count1++;break;case 1:if (count2 == 1){System.out.println("很抱歉,你没抽到");break;}System.out.println("恭喜你,你抽到了," + 188);count2++;break;case 2:if (count3 == 1){System.out.println("很抱歉,你没抽到");break;}System.out.println("恭喜你,你抽到了," + 666);count3++;break;case 3:if (count4 == 1){System.out.println("很抱歉,你没抽到");break;}System.out.println("恭喜你,你抽到了," + 520);count4++;break;case 4:if (count5 == 1){System.out.println("很抱歉,你没抽到");break;}System.out.println("恭喜你,你抽到了," + 99999);count5++;break;default:System.out.println("出错了,请重试");break;}} else {System.out.println("请输入正确的键以开始抽奖");return;}}}
}

 可以看到代码十分冗余繁杂,来看看老师是怎么实现的:

下面有两种方案,方案一和上面类似,都存在效率低下,可能多次重复寻找的问题。

方案一:

数组中每个位置的值代表红包金额,取的时候看该位置值是否为0,是0则继续循环寻找;不是0则取该数并将该位置的值置为0.

代码:

public class test_01 {public static void main(String[] args) {int[] arr = {9,666,188,520,99999};extractRedEnvelopes(arr);}public static void extractRedEnvelopes(int[] arr){System.out.println("有五个红包,分别是9,666,188,520,99999的");System.out.println("现在开始直播抽取红包");for (int i = 0; i < arr.length; i++) {System.out.println("输入任意内容开始抢红包");Scanner sc = new Scanner(System.in);sc.next();while (true){Random r = new Random();int money = r.nextInt(arr.length);if(arr[money] != 0){System.out.println("恭喜你,你抢到了"+arr[money]);arr[money] = 0;break;}else{System.out.println("抱歉,你没抢到");}}}}
}

方案二:

可以将初始红包的顺序打乱,也就是将数组中的数据顺序打乱,然后根据先来后到分配给抢红包的用户,这样有多少个红包就是分发多少次,不会出现重复查找效率低下的情况。

那么关键就在于打乱数组数据,可以依次遍历数组元素,根据随机索引调换数据位置,以达到打乱数据的效果。

代码:

public class test_01 {public static void main(String[] args) {extractRedEnvelopes();}public static void extractRedEnvelopes(){System.out.println("有五个红包,分别是9,666,188,520,99999的");System.out.println("现在开始直播抽取红包");System.out.println("输入任意内容开始抽取");int[] arr = {9,666,188,520,99999};disruptingData (arr); //打乱数组数据Scanner sc = new Scanner(System.in);sc.next();for (int i = 0; i < arr.length; i++) {System.out.println("恭喜"+(i+1)+"号观众,"+"你抽到了"+arr[i]);}}public static void disruptingData(int[] arr){Random r = new Random();for (int i = 0; i < arr.length; i++) {int ran = r.nextInt(arr.length);int tmp = arr[i];arr[i] = arr[ran];arr[ran] = tmp;}}
}

案例七:找素数的三种方法

我的思考:

素数是除了1和自己本身,其他数都不能整除的数。那么就依次遍历101~200的每个数,用2~ (i-1)的数去尝试能否被整除,不能就是素数。

我的代码:

public class test_01 {public static void main(String[] args) {findingPrimeNumbers();}public static void findingPrimeNumbers(){int[] arr = new int[100];int k = 0;for (int i = 101; i < 200; i++) {int flag = 1;for(int j = 2; j < i-1; j++){if(i % j == 0) {flag = 0;break;}}if(flag == 1)  arr[k++] = i;}System.out.println(Arrays.toString(arr));}
}

这段代码效率低,因为进行了多余操作,其实不用将 2~ (i-1)的数都试一遍的,只需要一半的数字足矣。

下面来看一下老师的代码:

public class test_01 {public static void main(String[] args) {System.out.println("请输入要查找的素数范围:");Scanner sc = new Scanner(System.in);int start = sc.nextInt();int end = sc.nextInt();int count = findingPrimeNumbers(start,end);System.out.println("素数的个数为" + count);}public static int findingPrimeNumbers(int start,int end) {assert (start > 0 && end > 0 && start < end);int count = 0;for (int i = start; i <= end; i++) {boolean flag = true;for (int j = 2; j < i / 2; j++) {if (i % j == 0) {flag = false;break;}}if (flag == true) {System.out.println("素数有" + i + " ");count++;}}return count;}
}

 方案三

public class test_01 {public static void main(String[] args) {System.out.println("请输入要查找的素数范围:");Scanner sc = new Scanner(System.in);int start = sc.nextInt();int end = sc.nextInt();for(int i = start;i <= end; i++){if(findingPrimeNumbers(i)) System.out.println(i+"是素数");}}public static boolean findingPrimeNumbers(int num) {for(int i = 2;i < num/2; i++){if(num % i == 0) return false;}return true;}

这种方案就是先建立一个判断是否为素数的方法,来一个数就放到该方法中判断,更加方便,也更贴近工作中编程的思想。

案例八:打印乘法口诀表

我的思考:

主要是注意一个格式,内层循环外层循环的嵌套。外层行,内层列。

我的代码: 

public class test_01 {public static void main(String[] args) {for(int i = 1;i <= 9;i++){for(int j = 1;j <= i;j++){System.out.print(j+" * "+i+" = "+i*j+"  ");}System.out.println();}}
}

案例九:打印三角形

我的思考:

第一行:3空格+ 1星

第二行:2空格+3星

第三行:1空格+5星

第四行:0空格+7星

我的代码:

public class test_01 {public static void main(String[] args) {for(int i = 1;i <= 4;i++){for(int j = 1;j <= (4-i);j++){System.out.print(" ");}for (int j = i; j <= (2*i-1) ; j++) {System.out.print("*");}System.out.println();}}
}

案例十:模拟双色球

 

 我的思考:

如上图所示,三色球的实现需要三个方法:用户投注号码,中奖标准号码,判断中几等奖。

可以将投注号码和中奖号码存在数组中返回,最终比较投注号码和中奖号码以判断中奖情况。

我的代码:

第一次理解错了,以为是每一等中奖号码要手动输入,麻烦了很多。

public class test_01 {public static void main(String[] args) {int[] userNumbers = userSelectNumbers();String[] luckNumbers = creatLuckNumbers();judge(userNumbers,luckNumbers);}public static int[] userSelectNumbers(){int[] userNumbers = new int[7];System.out.println("请输入你的投注号码,前6位1~33,最后一位1~16");Scanner sc = new Scanner(System.in);for (int i = 0; i < userNumbers.length; i++) {userNumbers[i] = sc.nextInt();assert(userNumbers[i] > 0 && userNumbers[i] < 34);assert (userNumbers[6] > 0 && userNumbers[6] < 17);}return userNumbers;}public static String[] creatLuckNumbers(){String[] luckNumbers = new String[9];int[] eachNumbers = new int[7];for (int k = 0; k < luckNumbers.length; k++) {System.out.println("请输入第"+(k+1)+"级中奖号码:");Scanner sc = new Scanner(System.in);for (int i = 0; i < eachNumbers.length; i++) {eachNumbers[i] = sc.nextInt();assert(eachNumbers[i] > 0 && eachNumbers[i] < 34);assert (eachNumbers[8] > 0 && eachNumbers[8] < 17);}luckNumbers[k] = Arrays.toString(eachNumbers);System.out.println((k+1)+"级中奖号码是:"+ Arrays.toString(eachNumbers));}return luckNumbers;}public static void judge(int[] userNumbers,String[] luckNumbers){for(int i = 0;i < luckNumbers.length;i++){if(Arrays.toString(userNumbers).equals(luckNumbers[i])){switch (i){case 0:System.out.println("恭喜你,中了一等奖");break;case 1:System.out.println("恭喜你,中了二等奖");break;case 2,3:System.out.println("恭喜你,中了三等奖");break;case 4,5:System.out.println("恭喜你,中了四等奖");break;case 6,7:System.out.println("恭喜你,中了五等奖");break;case 8,9:System.out.println("恭喜你,中了六等奖");break;}}else System.out.println("很抱歉,你没中奖。");}}
}

改正:

public class test_01 {public static void main(String[] args) {int[] userNumbers = userSelectNumbers();int[] luckNumbers = creatLuckNumbers();judge(userNumbers,luckNumbers);}public static int[] userSelectNumbers(){int[] userNumbers = new int[7];System.out.println("请输入你的投注号码,前6位1~33,最后一位1~16");Scanner sc = new Scanner(System.in);for (int i = 0; i < userNumbers.length; i++) {userNumbers[i] = sc.nextInt();if(userNumbers[i] < 1 || userNumbers[i] > 33) {System.out.println("请输入合法的号码");System.exit(-1);}for(int j = 0;j < i;j++){if(userNumbers[j] == userNumbers[i]) {System.out.println("请勿输入同样的号码!");break;}}}if(userNumbers[6] < 1 || userNumbers[6] > 16) {System.out.println("请输入合法的号码");System.exit(-1);}return userNumbers;}public static int[] creatLuckNumbers(){int[] luckNumbers = new int[7];System.out.println("请输入中奖号码,前6位1~33,最后一位1~16");Scanner sc = new Scanner(System.in);for (int i = 0; i < luckNumbers.length; i++) {luckNumbers[i] = sc.nextInt();if(luckNumbers[i] < 1 || luckNumbers[i] > 33){System.out.println("请输入合法的号码");System.exit(-1);}for(int j = 0;j < i;j++) {if (luckNumbers[j] == luckNumbers[i]) {System.out.println("请勿输入同样的号码!");break;}}}if(luckNumbers[6] < 1 || luckNumbers[6] > 16) {System.out.println("请输入合法的号码");System.exit(-1);}return luckNumbers;}public static void judge(int[] userNumbers,int[] luckNumbers){int count = 6, flag = 1;for (int i = 0; i < userNumbers.length-1; i++) {if(userNumbers[i] != luckNumbers[i]) count--;}if(userNumbers[6] != luckNumbers[6]) flag = 0;switch(count){case 0,1:if(flag == 1)  System.out.println("恭喜,你中了六等奖");else  System.out.println("很抱歉,你没有中奖");break;case 2,3:if(flag == 1) System.out.println("恭喜,你中了五等奖");else  System.out.println("很抱歉,你没有中奖");break;case 4:if(flag == 1) System.out.println("恭喜,你中了四等奖");else  System.out.println("恭喜,你中了五等奖");break;case 5:if(flag == 1) System.out.println("恭喜,你中了三等奖");else  System.out.println("恭喜,你中了四等奖");break;case 6:if(flag == 1) System.out.println("恭喜,你中了一等奖");else  System.out.println("恭喜,你中了二等奖");break;default:System.out.println("error");break;}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/140133.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

Python项目Flask ipv6双栈支持改造

一、背景 Flask 是一个微型的(轻量)使用Python 语言开发的 WSGI Web 框架(一组库和模块),基于Werkzeug WSGI工具箱/库和Jinja2 模板引擎,当然,Python的WEB框架还有:Django、Tornado、Webpy,这暂且不提。 Flask使用BSD授权。 Flask也被称为microframework(微框架),F…

【UE 粒子练习】02——使用一些常用的模块来创建粒子

目录 效果 步骤 一、创建材质 二、创建粒子 2.1 必需模块 2.2 初始大小模块 2.3 初始位置模块 2.4 初始速度模块 2.5 生命周期模块 2.6 加速-》恒加速度模块 2.7 生成模块 2.8 生命内颜色模块 2.9 尺寸-》大小随速度模块 2.10 碰撞-》Actor碰撞模块 2.1…

stack与queue的简单封装

前言&#xff1a; stack与queue即栈和队列&#xff0c;先进后出/先进先出的特性我们早已了然于心&#xff0c; 在学习数据结构时&#xff0c;我们利用c语言实现栈与队列&#xff0c;从结构体写起&#xff0c;利用数组或指针表示他们的数据成员&#xff0c;之后再一个个实现他们…

(避开网上复制操作)最详细的树莓派刷机配置(含IP固定、更改国内源的避坑操作、SSH网络登录、VNC远程桌面登录)

一、准备工作 SD卡格式化 二、 树莓派系统环境搭建&#xff08;官方&#xff09; 官方镜像 1.1、 必备的配件 读卡器&#xff0c; 内存卡&#xff08;强烈推荐 32GB 内存卡&#xff0c; #lite 命令行界面版本至少需要 8G&#xff0c; 图形化带桌面版镜像需要 16GB&#xf…

笔试强训Day(一)

T1&#xff1a;组队竞赛 链接&#xff1a;组队竞赛__牛客网 牛牛举办了一次编程比赛,参加比赛的有3*n个选手,每个选手都有一个水平值a_i.现在要将这些选手进行组队,一共组成n个队伍,即每个队伍3人.牛牛发现队伍的水平值等于该队伍队员中第二高水平值。 例如: 一个队伍三个队员…

自己写过比较蠢的代码:从失败中学习的经验

文章目录 引言1. 代码没有注释2. 长函数和复杂逻辑3. 不恰当的变量名4. 重复的代码5. 不适当的异常处理6. 硬编码的敏感信息7. 没有单元测试结论 &#x1f389; 自己写过比较蠢的代码&#xff1a;从失败中学习的经验 ☆* o(≧▽≦)o *☆嗨~我是IT陈寒&#x1f379;✨博客主页&a…

Postgresql事务测试

参考一个事务中 可以查询自己未提交的数据吗_最详细MySQL事务隔离级别及原理讲解&#xff01;&#xff08;二&#xff09;-CSDN博客 一个事务中 可以查询自己未提交的数据吗_趣说数据库事务隔离级别与原理_weixin_39747293的博客-CSDN博客 【MySql&#xff1a;当前读与快照读…

eNSP基础网络学习-v02

一、eNSP 1.什么是eNSP eNSP(Enterprise Network Simulation Platform)是一款由华为提供的免费的、可扩展的、图形化操作的网络仿真工具平台&#xff0c;主要对企业网络路由器、交换机进行软件仿真&#xff0c;完美呈现真实设备实景&#xff0c;支持大型网络模拟&#xff0c;让…

stm32之看门狗

STM32 有两个看门狗&#xff0c;独立看门狗和窗口看门狗&#xff0c;独立看门狗又称宠物狗&#xff0c;窗 口看门狗又称警犬。可用来检测和解决由软件错误引起的故障。两个看门狗的原理都是当计数器达到给定的超时值时&#xff0c;产生系统复位&#xff0c;对于窗口型看门狗同…

VMware中安装Ubuntu(2023年)

Ubuntu安装 前言 安装过程中电脑发热时正常的&#xff0c;这个还是稍微有点点大&#xff1b;下载的版本根据自己的喜好来&#xff0c;新版本肯定要比旧版本占用的空间更大&#xff0c;大家自行选择&#xff1b;仅供学习使用的话可以下载成熟稳定的版本&#xff0c;例如16、18…

《Kubernetes部署篇:Ubuntu20.04基于containerd部署kubernetes1.25.14集群(多主多从)》

一、架构图 如下图所示: 二、环境信息 1、资源下载基于containerd部署容器版kubernetes1.25.14集群资源合集 2、部署规划主机名K8S版本系统版本内核版本IP地址备注k8s-master-121.25.14Ubuntu 20.04.5 LTS5.15.0-69-generic192.168.1.12master节点 + etcd节点k8s-master-131.…

摸鱼也摸鱼之在线数独自动求解

背景 在发现被老板CPU之后&#xff0c;大家想做的基本上都是摸鱼&#xff0c;像我这种没什么手法的人不可能摸鱼打MOBA游戏&#xff0c;所以只能选择数独这种对时间要求不怎么急促的小游戏。然而&#xff0c;有时候搞半天才发现从一开始就错了&#xff0c;这让我很苦恼&#x…

java多线程学习笔记一

一、线程的概述 1.1 线程的相关概念 1.1.1 进程&#xff08;Process&#xff09; 进程&#xff08;Process&#xff09;是计算机的程序关于某数据集合上的一次运行活动&#xff0c;是操作系统进行资源分配与调度的基本单位。 可以把进程简单的理解为操作系统中正在有运行的一…

Java由浅入深理解线程池设计和原理

目录 1 线程1.1 什么是线程&#xff1f;什么是进程&#xff1f;1.2 java中线程的实现方式有几种?1.3 线程的生命周期是什么&#xff1f; 2 线程存在的问题2.1 一个线程只能执行一个任务2.2 线程执行完后销毁,无法复用2.3 线程过多,导致JVM宕机 3 初识线程池3.1 了解J.U.C3.2 线…

Webpack监视文件修改,自动重新打包文件

方法一&#xff1a;使用watch监视文件变化 在终端中输入以下指令&#xff1a; npx webpack --watch 我们使用这种方法监听文件变化时只会监听我们计算机本地的文件变化&#xff0c;在开发场景中我们的项目是要部署到服务器中的&#xff0c;因此这种方式并不推荐。 方法二&…

【C语言】指针经典笔试题(上)

C语言的一大重头戏就是指针。 对于指针有一些认识&#xff1a; 1.指针是存放变量的地址&#xff0c;一般说的指针和指针变量是一个概念。 2.地址的单位是字节&#xff0c;大小在不同编译器环境下有所不同&#xff0c;32位机器是4个字节&#xff0c;64位机器是8个字节。 3.数组名…

购物H5商城架构运维之路

一、引言 公司属于旅游行业&#xff0c;需要将旅游&#xff0c;酒店&#xff0c;购物&#xff0c;聚合到线上商城。通过对会员数据进行聚合&#xff0c;形成大会员系统&#xff0c;从而提供统一的对客窗口。 二、业务场景 围绕更加有效地获取用户&#xff0c;提升用户的LTV&a…

linux进程杀不死

项目场景&#xff1a; 虚拟机 问题描述 linux进程杀不死 无反应 原因分析&#xff1a; 进程僵死zombie 解决方案&#xff1a; 进proc或者find命令找到进程所在地址 cat status查看进程杀死子进程

2023 第十二届中国智能产业高峰论坛 - 文档大模型的未来展望

目录 前言文档图像分析识别与理解中的技术挑战 文档图像分析识别与理解的研究主题文档图像分析与预处理文档解析与识别版面分析与还原文档信息抽取与理解AI安全知识化&存储检索和管理 多模态大模型在文档图像处理中的应用多模态的GPT-4在文档图像上的表现多模态的Google Ba…