Java list乱序的实现三种方法
一:概述
在java学习对一些数据进行处理时,经常会将其顺序打乱,这里将讲述一下list的顺序打乱方法,将利用不同的方法去实现。
二:具体说明
<1>list集合的简单介绍和其特点
List集合为列表类型,以线性方式存储对象。List集合中的元素允许重复,各元素的顺序就是对象插入的顺序。用户可以通过使用索引来访问List集合中的元素。
特点:存取有序,可以存储重复的元素,可以利用下标对元素进行操作。
<2>方法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);
<3>方法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); }
<4>方法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); }
注意:这种方法主要是使用Stream API和随即比较器相结合来对list集合进行打乱。
到此这篇关于Java list乱序的实现三种方法的文章就介绍到这了,更多相关Java list乱序内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
基于Spring中的事务@Transactional细节与易错点、幻读
这篇文章主要介绍了基于Spring中的事务@Transactional细节与易错点、幻读,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-11-11Java service层获取HttpServletRequest工具类的方法
今天小编就为大家分享一篇关于Java service层获取HttpServletRequest工具类的方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧2018-12-12解决MyEclipse中的Building workspace问题的三个方法
这篇文章主要介绍了解决MyEclipse中的Building workspace问题的三个方法,需要的朋友可以参考下2015-11-11springboot中rabbitmq实现消息可靠性机制详解
这篇文章主要介绍了springboot中rabbitmq实现消息可靠性机制详解,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下2021-09-09
最新评论