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); } } } }