码迷,mamicode.com
首页 > 其他好文 > 详细

shuffling

时间:2015-06-10 22:35:32      阅读:247      评论:0      收藏:0      [点我收藏+]

标签:算法   randomize   shuffling   

  Shuffling is a procedure used to randomize a deck of playing cards to provide an element of chance in card games.
  Shuffling的目标是要Shuffling后所有可能情况的概率一样。
  
Before:
技术分享
After:
技术分享

这里介绍两种简单的shuffling算法:
1)Sort shuf?e :
?Generate a random real number for each array entry.
?Sort the array.
技术分享
技术分享

2)Knuth shuffle:
?In iteration i, pick integer r between 0 and i uniformly at random.
?Swap a[i] and a[r].

public class Knuth
{
   public static void shuffle(Object[] a)
   {
     int N = a.length;
     for (int i = 0; i < N; i++)
     {
       int r = StdRandom.uniform(i + 1);
       exch(a, i, r);
     }
   }
}

如果,这里不是在[0,i]间产生r,而是在[0,N-1]产生r,将会产生Broken Knuth shuf?e,其每种情况将不是等概率的。
技术分享

shuffling

标签:算法   randomize   shuffling   

原文地址:http://blog.csdn.net/kzq_qmi/article/details/46446591

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