当前位置: 首页 > news >正文

Java综合练习04

1.数字解密

加密:

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

按上述规则解密 

参考代码:

public class Text1 {public static void main(String[] args) {//定义数组记录解密后的结果int[] arr = {8, 3, 4, 6};//反转for (int i = 0, j = arr.length - 1; i < j; i++, j--) {int temp = arr[i];arr[i] = arr[j];arr[j] = temp;}//加密是通过对10取余的方式进行获取的//所以在解密时就需要判断,0~4之间+10,5~9之间的数字不变for (int i = 0; i < arr.length; i++) {if (arr[i] >= 0 && arr[i] <= 4) {arr[i] = arr[i] + 10;}}//每一位减5for (int i = 0; i < arr.length; i++) {arr[i] = arr[i] - 5;}//拼接int number = 0;for (int i = 0; i < arr.length; i++) {number = number * 10 + arr[i];}System.out.println(number);}
}

2. 抽奖的两种实现方式

需求

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

分析:

  • 定义数组表示奖池
  • 定义新数组存储抽奖结果
  • 获取随机索引
  • 抽奖

参考代码一:

import java.util.Random;public class Text2 {public static void main(String[] args) {//定义数组表示奖池int[] arr = {2, 588, 888, 1000, 10000};//定义新数组存储抽奖结果int[] newArr = new int[arr.length];Random r = new Random();//5个奖项,循环五次for (int i = 0; i < 5; ) {//获取随机索引int randomIndex = r.nextInt(arr.length);//获取奖项int prize = arr[randomIndex];//判断当前的奖项是否存在,存在则重新抽取;不存在就表示是有效奖项boolean flag = contains(newArr, prize);if (!flag) {//把当前抽取的奖项添加到newArr中newArr[i] = prize;//添加完毕,移动索引i++;}}//遍历newArrfor (int i = 0; i < newArr.length; i++) {System.out.println(newArr[i]);}}//定义方法判断prize在数组中是否存在//存在:true;不存在:falsepublic static boolean contains(int[] arr, int prize) {for (int i = 0; i < arr.length; i++) {if (arr[i] == prize) {return true;}}return false;}
}

 参考代码二(优化)

  • 把奖池里的所有奖项打乱顺序
  • 遍历奖池,从0索引开始获取每一个奖项
import java.util.Random;public class Text3 {public static void main(String[] args) {int [] arr = {2,588,888,1000,10000};//把奖池里的所有奖项打乱顺序Random r = new Random();for (int i = 0; i < arr.length; i++) {//获取随机索引int randomIndex = r.nextInt(arr.length);//拿着i跟随机索引randomIndex上的值进行交换int temp = arr[i];arr[i] = arr[randomIndex];arr[randomIndex] = temp;}//遍历奖池for (int i = 0; i < arr.length; i++) {System.out.println(arr[i]);}}
}

3.二维数组 

就是数组中存数组

当我们需要把数据分组管理的时候,就需要用到二维数组

3.1 二维数组的初始化

静态初始化

  • 格式:数据类型 [][] 数组名 = new 数据类型 [][] {{元素1,元素2},{元素3,元素4}};
  • 示例:int [][] arr = new int [][] {{1,2,3},{4,5,6}};
  • 简化格式:数据类型 [][] 数组名 = {{元素1,元素2},{元素3,元素4}};
  • 示例:int [][] arr = {{1,2,3},{4,5,6}};

注意:

  • 每一个一维数组其实是二维数组中的元素,所以每一个一维数组之间需要用逗号隔开;最后一个一维数组后面不需要加逗号

  • 建议这样定义:把每一个一维数组单独写成一行

示例:

 int[][] arr = {{1, 2, 3},{4, 5, 6}};

动态初始化 

格式:

数据类型 [][] 数组名 = new 数据类型 [m][n];

  • m 表示这个二维数组可以存放多少个一维数组
  • n 表示每一个一维数组可以存放多少个元素 

示例:  int [][] arr = new int[2][3];

该数组可以存放2个一维数组,每一个一维数组可以存放3个int类型元素

3.2 获取元素/赋值

获取元素:

public class Text5 {public static void main(String[] args) {int[][] arr = {{1, 2, 3},{4, 5, 6}};//arr[0][0]:获取第一个一维数组中0索引的元素,即元素1//获取数组中的元素6System.out.println(arr[1][2]);
}
}

赋值:

 //给第一个一维数组中索引为0的元素赋值arr[0][0] = 10;

3.3 二维数组的遍历 

用两个循环,外循环和内循环

  • 外循环:遍历二维数组,得到里面的每一个一维数组
  • 内循环:遍历一维数组,得到里面的每一个元素

示例:

 //外循环//i表示二维数组中的每一个索引//arr[i]:表示二维数组中的每一个元素(一维数组)
for (int i = 0; i < arr.length; i++) {//内循环//j:表示一维数组中的每一个元素for (int j = 0; j < arr[i].length; j++) {//每个元素之间加一个空格System.out.print(arr[i][j] + " ");}//内循环结束后,·表示一个一维数组遍历完毕System.out.println();//换行
}

3.4 二维数组练习 

某商城每个季度的营业额如下:单位(万元)

第一季度:22,66,44

第二季度:77,33,88

第三季度:25,45,65

第四季度:11,66,99

需求:计算出每个季度的总营业额和全年的总营业额

分析:

  • 创建二维数组并存储数据
  • 遍历二维数组,得到每一个一维数组并求和
  • 定义一个方法,计算每一个季度的营业额

参考代码:

public class Text7 {public static void main(String[] args) {int[][] yearArrArr = {{22, 66, 44},{77, 33, 88},{25, 45, 65},{11, 66, 99}};//全年的营业额int yearSum = 0;//遍历,得到每一个一维数组for (int i = 0; i < yearArrArr.length; i++) {//yearArrArr[i]:每一个一维数组int[] quarterArr = yearArrArr[i];int sum = getSum(quarterArr);System.out.println("第" + (i + 1) + "个季度的总营业额为:" + sum);yearSum = yearSum + sum;}System.out.println("全年的总营业额为:" + yearSum);}public static int getSum(int[] arr) {int sum = 0;for (int i = 0; i < arr.length; i++) {sum = sum + arr[i];}return sum;}
}

http://www.dtcms.com/a/266076.html

相关文章:

  • js代码中的作用域
  • 深度学习×第4卷:Pytorch实战——她第一次用张量去拟合你的轨迹
  • Mausezahn - 网络流量生成与测试工具(支持从链路层到应用层的协议模拟)
  • C++ 解决类相互引用导致的编译错误
  • 状态码301和302的区别
  • 智能设备远程管理:基于OpenAI风格API的自动化实践
  • 渗透靶机 Doctor 复盘
  • 粘包问题介绍
  • JS模块导出导入笔记 —— 默认导出 具名导出
  • 【嵌入式电机控制#8】编码器测速实战
  • C++讲解—类(2)
  • MCP+Cursor入门
  • AI 日报:阿里、字节等企业密集发布新技术,覆盖语音、图像与药物研发等领域
  • 前缀和与差分算法详解
  • 线程池相关介绍
  • SpringSecurity01
  • 【libm】 7 双精度正弦函数 (k_sin.rs)
  • 从混沌到澄明,AI如何重构我们的决策地图与未来图景
  • 把大象塞进冰箱总共分几步:讲讲dockerfile里conda的移植
  • IOC容器讲解以及Spring依赖注入最佳实践全解析
  • XILINX FPGA如何做时序分析和时序优化?
  • Linux之Socket编程Tcp
  • 【BurpSuite 2025最新版插件开发】基础篇7:数据的持久化存储
  • snail-job的oracle sql(oracle 11g)
  • 百度捂紧“钱袋子”
  • 冒泡排序及其优化方式
  • Javaweb - 10.1 Servlet
  • 两个手机都用同个wifi,IP地址会一样吗?如何更改ip地址
  • Redis实战:数据安全与性能保障
  • linux测试端口是否可被外部访问