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

  

作者:周可乐原文地址:https://www.cnblogs.com/cola-zhou/p/18258817

%s 个评论

要回复文章请先登录注册