码迷,mamicode.com
首页 > 编程语言 > 详细

数组洗牌算法-shuffle

时间:2017-12-09 16:46:08      阅读:240      评论:0      收藏:0      [点我收藏+]

标签:and   --   return   取出   www   随机   math   概率   das   

数组洗牌,最近直接的想法是从数组随机取出一个元素,放到另一个数组中,但是这样取出的元素会有重复,必须采取一定的方法保证:

1. 元素不能重复
2. 元素被抽取的概率相等,即随机性

数组洗牌经典算法有两种:

1. Fisher-Yates Shuffle(复杂度(n^2))

数组的删除以及新的copy数组都是耗费时间和空间的。

javascript实现

function FyShuffle(arr){
    var copy = [],
        len = arr.length,
        n;
    while(len)
        n = Math.floor(Math.random() * len--);
        res.push(arr.splice(n,1)[0]);
    }
    return copy;
}

2. Knuth-Durstenfeld Shuffle(复杂度(n),是Fisher-Yates算法的改进版本)

kd方法是一种in-place的置换方法,节省空间,性能也好,随机性好,python内置的random.shuffle用了此算法。

javascript实现

function KdShuffle(arr){
    var len = arr.length,
        i,temp;
    while(len){
        i = Math.floor(Math.random() * len--);
        temp = arr[i];
        arr[i] = arr[len];
        arr[len] = temp;
    }
    return arr;
}

 

 

参考:http://www.cnblogs.com/Wayou/p/fisher_yates_shuffle.html
   http://www.cnblogs.com/tudas/p/3-shuffle-algorithm.html

数组洗牌算法-shuffle

标签:and   --   return   取出   www   随机   math   概率   das   

原文地址:http://www.cnblogs.com/mengff/p/8011713.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!