您的位置:首页 > 其它

产生N个不重复的随机数的快速算法

2015-06-18 10:55 246 查看
转自:http://blog.csdn.net/devfun/article/details/6534476和http://www.cnblogs.com/Imageshop/p/3430742.html

今儿写一段生成随机数的东西,需要用到产生N个“不重复”的随机数算法,研究了半天,找到一种快速的解决办法:

int startArray[] = {0,1,2,3,4,5,6,7,8,9};//seed array
int N = 10;//随机数个数
int resultArray[] = new int [10];//结果存放在里面
for(int i = 0; i < N; i++)
{
int seed = random(0, startArray.length - i);//从剩下的随机数里生成
resultArray[i] = startArray[seed];//赋值给结果数组
startArray[seed] = startArray[startArray.length - i - 1];//把随机数产生过的位置替换为未被选中的值。
}
或者

private static int[] RandPerm(int N)
{
int X;
Random Rnd = new Random(Environment.TickCount);
int[] TempArray = new int
;
int[] Value = new int
;
for (X = 0; X < N; X++) TempArray[X] = X;
for (X = 0; X < N; X++)
{
int Seed = Rnd.Next(0, N - X);           //从剩下的随机数里生成
Value[X] = TempArray[Seed];                 //赋值给结果数组
TempArray[Seed] = TempArray[N - X - 1];   //把随机数产生过的位置替换为未被选中的值。
}
return Value;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: