/**
 * 考核点:随机数获取;数组集合遍历;整型与字符串转换;字符串字符遍历;数组/集合排序
 * <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);
            }
        }

    }
}