登录
首页 >  文章 >  java教程

在 Java 中使用 Fisher-Yates 算法对数组进行洗牌

来源:dev.to

时间:2024-10-02 20:09:59 281浏览 收藏

本篇文章给大家分享《在 Java 中使用 Fisher-Yates 算法对数组进行洗牌》,覆盖了文章的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。

在 Java 中使用 Fisher-Yates 算法对数组进行洗牌

介绍

在计算机科学领域,对数组或元素列表进行洗牌是一种常见的操作,可用于各种应用程序,从随机化游戏结果到分发牌组中的纸牌。为此目的最有效的算法之一是 fisher-yates shuffle,也称为 knuth shuffle。该算法确保数组的每个排列都有相同的可能性,这使其成为创建无偏随机洗牌的理想选择。

在本文中,我们将探讨 fisher-yates shuffle 算法的 java 实现。提供的代码有效地对整数数组进行了适当的洗牌,展示了该算法的优雅性和有效性。

fisher-yates 洗牌算法

fisher-yates shuffle 算法的运行方式是从末尾到开头迭代数组,将每个元素与数组中较早出现的随机选择的元素(包括当前位置)交换。此过程确保数组的所有排列都是同等概率的。

java代码实现

这是 fisher-yates shuffle 算法的 java 实现:

import java.util.*;

class FYShuffleAlgorithm {
    public static void main(String[] args) {
        int[] arr = {1, 2, 3, 4, 5, 6};

        shuffle(arr);
    }

    public static void shuffle(int[] arr) {
        Random rand = new Random();
        for (int i = arr.length - 1; i > 0; i--) {
            int randomIndex = rand.nextInt(i + 1);
            int tmp = arr[i];
            arr[i] = arr[randomIndex];
            arr[randomIndex] = tmp;
        }
        System.out.println(Arrays.toString(arr));
    }
}

代码说明
初始化:
main 方法使用值 {1, 2, 3, 4, 5, 6} 初始化一个整数数组 arr,然后调用 shuffle 方法来对这个数组进行洗牌。

好了,本文到此结束,带大家了解了《在 Java 中使用 Fisher-Yates 算法对数组进行洗牌》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!

声明:本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>