0
点赞
收藏
分享

微信扫一扫

Java list顺序打乱

一:概述

在java学习对一些数据进行处理时,经常会将其顺序打乱,这里将讲述一下list的顺序打乱方法,将利用不同的方法去实现。

二:具体说明

<1>list集合的简单介绍和其特点

List集合为列表类型,以线性方式存储对象。List集合中的元素允许重复,各元素的顺序就是对象插入的顺序。用户可以通过使用索引来访问List集合中的元素。

特点:存取有序,可以存储重复的元素,可以利用下标对元素进行操作。

<2>list顺序打乱方法1:使用Collections.shuffle()方法进行实现

  List<Integer> numbers = new ArrayList<Integer>();
          for(int i = 1; i <= 20; i++ ) {
              numbers.add(i);
          }
 System.out.println("原来的顺序为:" + numbers);
 Collections.shuffle(numbers);
System.out.println("打乱后的顺序:" + numbers);

Java list顺序打乱_i++

<2>list顺序打乱方法2:自定义打乱算法---使用random

public static void customShuffle(List<Integer> list) {
        Random random = new Random();
        for (int i = list.size() - 1; i > 0; i--) {
            int j = random.nextInt(i + 1);
            int temp = list.get(i);
            list.set(i, list.get(j));
            list.set(j, temp);
        }
    }

    public static void main(String[] args) {
        List<Integer> numbers = new ArrayList<>();
        for (int i = 1; i <= 20; i++) {
            numbers.add(i);
        }

        System.out.println("原始顺序:" + numbers);

        customShuffle(numbers);

        System.out.println("自定义打乱后的顺序:" + numbers);
    }

Java list顺序打乱_i++_02

<3>list顺序打乱方法3:使用Stream API去实现

 List<Integer> numbers = new ArrayList<Integer>();
               for(int i = 100; i >= 87;i-- ) {
                   numbers.add(i);
               }

               System.out.println("原始顺序为:" + numbers);

               List<Integer> shuffledNumbers = numbers.stream()
                       .sorted((a,b) ->Math.random() > 0.5 ? 1 : -1)
                       .collect(Collectors.toList());

               System.out.println("打乱后的顺序为:" + shuffledNumbers);
           }

Java list顺序打乱_System_03

注意:这种方法主要是使用Stream API和随即比较器相结合来对list集合进行打乱。

举报

相关推荐

0 条评论