- /**
- * 考核点:随机数获取;数组集合遍历;整型与字符串转换;字符串字符遍历;数组/集合排序
- * <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);
- }
- }
- }
- }
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |