collections.shuffle

简介: `Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的静态方法,基于 Fisher-Yates 算法实现,支持使用默认或自定义随机数生成器,适用于抽奖、游戏、随机抽样等场景,且会直接修改原列表。

在 Java 中,Collections.shuffle() 方法是 java.util.Collections 类提供的一个静态方法,用于 随机打乱 给定列表(List)中的元素顺序。它使用伪随机数生成器来重新排列集合中的元素,因此每次调用时,元素的顺序都会不同。

Collections.shuffle() 方法详解

1. 方法签名

public static void shuffle(List<?> list)
  • 参数list — 要打乱顺序的 List 集合。
  • 返回值:该方法没有返回值,它会直接修改传入的列表(即原地修改)。

2. 方法原理

Collections.shuffle() 方法通过使用 java.util.Random 进行随机排列,它的实现使用了 Fisher-Yates 洗牌算法,该算法是一种高效且公平的随机排序算法,能够保证每种可能的排列都具有相同的概率。

3. 可选参数:自定义 Random 对象

shuffle() 方法还可以接收一个自定义的 Random 对象,允许我们指定随机数生成器的种子,这样可以保证每次运行时生成相同的随机顺序(即可重复性)。

public static void shuffle(List<?> list, Random rnd)
  • 参数

    • list — 要打乱顺序的 List 集合。
    • rnd — 自定义的 Random 对象,用于生成随机数。

示例 1:基本使用 Collections.shuffle()

import java.util.*;

public class ShuffleExample {
   
    public static void main(String[] args) {
   
        // 创建一个包含 1 到 10 的列表
        List<Integer> numbers = new ArrayList<>();
        for (int i = 1; i <= 10; i++) {
   
            numbers.add(i);
        }

        // 打印原始列表
        System.out.println("原始列表: " + numbers);

        // 使用 shuffle 方法打乱列表顺序
        Collections.shuffle(numbers);

        // 打印打乱后的列表
        System.out.println("打乱后的列表: " + numbers);
    }
}

输出:

原始列表: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
打乱后的列表: [6, 4, 1, 9, 7, 8, 2, 3, 10, 5]

说明:

每次执行 Collections.shuffle() 时,打乱的顺序都会不同。


示例 2:使用自定义的 Random 对象

通过传递一个自定义的 Random 对象,可以确保每次运行时使用相同的随机顺序(可重复性)。

import java.util.*;

public class ShuffleWithRandom {
   
    public static void main(String[] args) {
   
        // 创建一个包含 1 到 10 的列表
        List<Integer> numbers = new ArrayList<>();
        for (int i = 1; i <= 10; i++) {
   
            numbers.add(i);
        }

        // 创建一个随机数生成器并设置种子
        Random random = new Random(42); // 固定种子,保证每次执行结果相同

        // 打乱列表顺序
        Collections.shuffle(numbers, random);

        // 打印打乱后的列表
        System.out.println("打乱后的列表: " + numbers);
    }
}

输出:

打乱后的列表: [6, 3, 1, 4, 9, 5, 7, 10, 8, 2]

说明:

因为使用了固定的随机种子(new Random(42)),每次运行此代码时,打乱后的顺序都相同。


何时使用 Collections.shuffle()

  • 抽奖或游戏:当你需要随机化一组数据(如洗牌、抽奖等)时,shuffle() 非常有用。
  • 随机抽样:在从大数据集中随机选择一部分数据时,可以先使用 shuffle() 方法随机打乱列表顺序。
  • 模拟随机事件:例如在模拟实验或测试时,可以使用它来产生不可预测的输出。

总结:

  • Collections.shuffle() 方法用于随机打乱列表中元素的顺序,通常用于实现随机排序或打乱操作。
  • 它有一个简单的版本和一个允许传入自定义 Random 对象的版本,后者可以确保可重复的随机顺序。
  • 需要注意的是,shuffle() 方法是 原地修改 列表的顺序,而不是返回一个新列表。

如果你有其他问题或者需要进一步的解释,随时告诉我!
https://www.52runoob.com/archives/4499

目录
相关文章
若依框架 --- ruoyi 表格的设置
若依框架 --- ruoyi 表格的设置
1733 0
|
2月前
|
安全 Java
JAVA:Collections类的shuffle()方法
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的工具方法,适用于洗牌、抽奖等场景。该方法直接修改原列表,支持自定义随机数生成器以实现可重现的打乱顺序。使用时需注意其原地修改特性及非线程安全性。
100 0
elasticsearch hanlp 插件安装操作
简要简述elasticsearch hanlp插件的基本安装操作
elasticsearch hanlp 插件安装操作
|
5月前
|
XML 前端开发 测试技术
如何使用 Postman 发送 POST XML 请求?
使用 Postman 发送带有 XML 数据的 POST 请求。我们将引导您完成将 XML 数据有效发送到 Web 服务或 API 的步骤,使处理这种常见数据格式变得简单易行。
|
2月前
|
存储 人工智能 缓存
SpringBoot离线应用的5种实现方式
在网络依赖日益加深的今天,离线应用的重要性不断上升。本文介绍了基于SpringBoot实现离线应用的五种方式,重点讲解了嵌入式数据库的实现原理与步骤,包括本地数据存储、操作缓存、资源本地化和状态管理等核心功能,分析了其优缺点及适用场景,帮助开发者在无网络环境下构建稳定可靠的应用。
144 0
|
2月前
|
机器学习/深度学习 运维 监控
智能运维Agent:自动化运维的新范式
在数字化转型浪潮中,智能运维Agent正重塑运维模式。它融合人工智能与自动化技术,实现从被动响应到主动预防的转变。本文详解其四大核心功能:系统监控、故障诊断、容量规划与安全响应,探讨如何构建高效、可靠的自动化运维体系,助力企业实现7×24小时无人值守运维,推动运维效率与智能化水平全面提升。
504 0
|
安全 Android开发 开发者
Service与Activity如何实现通信
Android为Service与Activity之间的通信提供了多种灵活的方式,开发者可以根据应用程序的需求选择合适的通信机制。对于多数简单通信需求,Intent和Binder通常就足够使用。另外,要注意线程安全和数据同步的问题,尤其是在多线程环境下操作UI或Service中的共享资源时。
396 0
|
11月前
|
前端开发 UED
长轮询(Long Polling)的缺点有哪些?
【10月更文挑战第8天】
330 2
|
10月前
|
网络虚拟化 数据安全/隐私保护 数据中心
对比了思科和华为网络设备的基本配置、接口配置、VLAN配置、路由配置、访问控制列表配置及其他重要命令
本文对比了思科和华为网络设备的基本配置、接口配置、VLAN配置、路由配置、访问控制列表配置及其他重要命令,帮助网络工程师更好地理解和使用这两个品牌的产品。通过详细对比,展示了两者的相似之处和差异,强调了持续学习的重要性。
511 2
|
11月前
|
JavaScript 数据可视化 开发者
echart:里面的属性
这段内容介绍了图表配置中的多个关键组件和属性,包括 `xAxis` 和 `yAxis` 的常见属性设置、`grid` 的布局调整、`dataZoom` 的数据缩放功能、`legend` 的图例配置以及颜色配置等。通过这些配置,可以实现图表的自定义显示,如坐标轴类型、数据源、最小值、最大值、刻度间隔、标签样式、线条样式等,同时还能调整图表在 DOM 元素中的大小和位置,以及实现数据的缩放和平滑交互效果。
274 0