DEMO_02:随机数获取;数组集合遍历;整型与字符串转换;字符串字符遍历;数组/集合排序
/**
* 考核点:随机数获取;数组集合遍历;整型与字符串转换;字符串字符遍历;数组/集合排序
* <p>
* 题目:
* 1. 使用while循环获取20个五位数随机数并打印;
* 2. 遍历20个数,筛选出随机数中3的倍数,并统计个数;
* 3. 符合2的数中,找出五位数中3的倍数和位置
* 4. 符合2的数中,把这五位数重新按从小到大排序
* 输出结果,1输出:[21324,64864,33279,97412,......]
* 234输出:
* 第1个符合条件数:21324;[3在第3位];重排序:12234
* 第2个符合条件数:33279;[3在第3位,3在第2位,9在第5位];重排序:23379
* .......
* 第n个符合条件数:xxxx;[],重排序:xxxxx
*/
public class Main02 {
public static void main(String[] args) {
//思考一下为什么要初始化大小数组集合;new ArrayList<>(20)
//回答:预估数据量初始化数组集合大小,避免数组在数组在存数据时发生数组扩容造成资源浪费
// 存放20个随机数
List<Integer> data = new ArrayList<>(20);
Random random = new Random();
while (data.size() < 20) {
int num = random.nextInt(90000) + 10000; //[0,90000) -> [10000,100000)
data.add(num);
}
System.out.println("初始化20个随机数:");
data.stream().forEach(one -> System.out.print(one + " "));
System.out.println();
// 遍历数据
int num = 0;
for (Integer one : data) {
// 统计3的倍数
if (one % 3 == 0) {
num++;
List<String> indexMsg = new ArrayList<>(); // 存放3的倍数的位置信息
List<String> dataList = new ArrayList<>();
// 遍历当前随机数的每个数字
char[] charArray = one.toString().toCharArray();
for (int i = 0; i < charArray.length; i++) {
String chStr = String.valueOf(charArray[i]);
Integer single = Integer.valueOf(chStr);
if (single % 3 == 0) {
String msg = single + "在第" + (i + 1) + "位";
indexMsg.add(msg);
}
dataList.add(chStr);
}
String indexResult = String.join(",", indexMsg); // 随机数中3的倍数定位信息
dataList.sort((o1, o2) -> Integer.valueOf(o2) - Integer.valueOf(o1));
String sortResult = String.join("", dataList); // 重排序结果
System.out.println("第" + num + "个符合条件数:" + one + ";[" + indexResult + "];重排序:" + sortResult);
}
}
}
}
DEMO_02:随机数获取;数组集合遍历;整型与字符串转换;字符串字符遍历;数组/集合排序DEMO_02:随机数获取;数组集合遍历;整型与字符串转换;字符串字符遍历;数组/集合排序DEMO_02:随机数获取;数组集合遍历;整型与字符串转换;字符串字符遍历;数组/集合排序DEMO_02:随机数获取;数组集合遍历;整型与字符串转换;字符串字符遍历;数组/集合排序DEMO_02:随机数获取;数组集合遍历;整型与字符串转换;字符串字符遍历;数组/集合排序DEMO_02:随机数获取;数组集合遍历;整型与字符串转换;字符串字符遍历;数组/集合排序DEMO_02:随机数获取;数组集合遍历;整型与字符串转换;字符串字符遍历;数组/集合排序DEMO_02:随机数获取;数组集合遍历;整型与字符串转换;字符串字符遍历;数组/集合排序DEMO_02:随机数获取;数组集合遍历;整型与字符串转换;字符串字符遍历;数组/集合排序