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

均匀随机排列数组

时间:2014-10-05 00:22:37      阅读:207      评论:0      收藏:0      [点我收藏+]

标签:blog   http   os   ar   java   for   sp   c   on   

均匀随机排列数组

RandomizePlace(char * Arry,int len)
{
 int temp;
 for(iny i=0;i<len;i++)
 {
  index=BlockRand(i,len);
  temp=Arry[i];
  Arry[i]=arry[index];
  Arry[index]=temp;
  }
 }

int BlockRand(int a,int b)  
{  
int r;  
r=rand()/RAND_MAX;  
return a+r*(b-a);  
}

Arry即为均匀随机排列数组。
随机排列数组满足这两个条件

  • 产生的排列个数是N!个
  • 每种排列的概率相同,即都为1/N!

Reference

[1].http://www.cnblogs.com/pangxiaodong/archive/2011/09/05/2167485.html

[2].算法导论.P66~P73

均匀随机排列数组

标签:blog   http   os   ar   java   for   sp   c   on   

原文地址:http://my.oschina.net/lvyi/blog/324252

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