3

可能重复:
使用 Random 和 OrderBy 是否是一个好的随机播放算法?

给定一个从0开始的n个连续数的整数数组,即

0,1,2,..n

我希望随机生成一个数字排列,

说给定

0,1,2,3

一个可能是3,1,2,0

如何轻松实现?

4

2 回答 2

11

首先创建一个所需大小的整数数组,并用不断增加的连续数字填充它;

int n = 10;
int[] array = new int[n + 1];
for (int i = 0; i <= n; i++)
{
    array[i] = i;
}
Shuffle(array);

你可以使用 Knuth / Fisher-Yates shuffle

/// <summary>
/// Knuth shuffle
/// </summary>        
public void Shuffle(int[] array)
{
    Random random = new Random();
    int n = array.Count();
    while (n > 1)
    {
        n--;
        int i = random.Next(n + 1);
        int temp = array[i];
        array[i] = array[n];
        array[n] = temp;
    }
}
于 2013-01-26T09:13:16.013 回答
9

这是使用 LINQ 和随机生成器的简单方法。

int[] numbers = new int[] { 1,2,3,4,5,6,7,8,9 };

Random rnd = new Random();
int[] MyRandomNumbers = numbers.OrderBy(x => rnd.Next()).ToArray();

参考:使用 .NET 随机化数组的最佳方法

于 2013-01-26T08:56:23.963 回答