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

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

最新文章

  1. Mysql 5.7 使用SSL安全连接
  2. 利用Roslyn构建一个简单的C#交互脚本引擎
  3. java 类加载顺序
  4. hdu 4259 Double Dealing
  5. 设计模式值六大原则——设计模式之六大原则——单一职责原则(SRP)
  6. 抽象工厂模式(Abstract Factory)
  7. reload(sys)后print失效问题解决
  8. Python爬虫实战之Requests+正则表达式爬取猫眼电影Top100
  9. 《Linux内核设计与实现》第一二章笔记
  10. process.cwd()与__dirname的区别
  11. es的timeout机制
  12. vue2.0 中#$emit,$on的使用详解
  13. pthread mutex
  14. Jersey RESTful WebService框架学习(二)使用@PathParam
  15. 修改linux swap空间的swappiness,降低对硬盘的缓存
  16. Java&C#语法差别
  17. java学习(五)Number类、Math类
  18. 17、Cocos2dx 3.0游戏开发找小三之内置的经常使用层:三剑客LayerColor、LayerGradient、Menu
  19. 编写高质量代码改善C#程序的157个建议——建议109:谨慎使用嵌套类
  20. Django templates加载css/js/image等静态资源

热门文章

  1. bootstrap3 文档随看
  2. Java控制语句例题,for循环语句,if条件语句等,Scanner类与Random类,Math.max()方法
  3. Bootstrap 附加导航(Affix)插件
  4. C#事件与接口编程实例
  5. 二十三、MySQL 事务
  6. 基于js原生封装的点击显示完整文字
  7. web前端使用localstorage、sessionstorage、cookie增删获方法
  8. js中正则表达式与Python中正则表达式的区别
  9. 三次样条插值matlab实现
  10. Codeforces Round #459 (Div. 2)-A. Eleven