洗牌算法

Posted catlkb

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了洗牌算法相关的知识,希望对你有一定的参考价值。

洗牌算法

洗牌算法,刚在知乎这个回答上看到的一个算法,非常有趣。
通过概率论的知识原地实现了一个公平的随机算法。
大致的过程就是一个数组(假设有n个数),从后往前取第一个数A,第二个数随机从前面的数据中选取。最后算下来随机的概率是1/n。

代码如下

/**
 * @program: erp-user
 * @description:
 * @author: lkb
 * @create: 2020-01-16 13:22
 */
public class Test {

    public static void main(String[] args) {
        int[] arr = new int[]{6,34,27,4,9};
        System.out.println("初始数组:");
        Arrays.stream(arr).forEach(d-> System.out.print(d +", "));
        System.out.println();
        for(int i=arr.length-1;i>0;i--){
            int j = new Random().nextInt(i);
            swap(arr,i,j);
            System.out.println(arr[i] +" <-> " + arr[j] );
            Arrays.stream(arr).forEach(d-> System.out.print(d +", "));
            System.out.println();
        }
    }


    private static void swap(int[] arr, int a,int b){
        int tmp = arr[a];
        arr[a] = arr[b];
        arr[b] = tmp;
    }
}

以上是关于洗牌算法的主要内容,如果未能解决你的问题,请参考以下文章

洗牌算法

VB洗牌算法产生随机数组

扑克牌的完美洗牌算法

随机洗牌算法Knuth Shuffle和错排公式

常用算法篇-洗牌算法

程序员的算法趣题Q50: 完美洗牌