转自: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[N];
int[] Value = new int[N];
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;
}