0

我需要以随机顺序打印从 1 到 50 的数字而不重复它。

static void Main(string[] args)
{
     ArrayList r = new ArrayList();

     Random ran = new Random();      
     for (int i = 0; i < 50; i++)
     {
        r.Add(ran.Next(1,51));

     }

     for (int i = 0; i < 50; i++)
        Console.WriteLine(r[i]);
     Console.ReadKey();
}
4

3 回答 3

2

你想要的是Fisher Yates Shuffle

这是Jeff Atwood实现的算法

cards = Enumerable.Range(1, 50).ToList();
for (int i = cards.Count - 1; i > 0; i--)
{
  int n = ran.Next(i + 1);
  int temp = cards[i];
  cards[i] = cards[n];
  cards[n] = temp;
}
于 2013-10-04T10:34:17.667 回答
1

如果您不想重复 1 到 50 之间的数字,最好的办法是用数字 1 到 50 填充列表,然后随机播放内容。这里有一篇关于洗牌的好帖子: Randomize a List<T>

于 2013-10-04T10:14:02.620 回答
0

您需要做的就是检查该号码是否已存在于列表中,如果存在则获取另一个:

static void Main(string[] args)
{
    ArrayList r = new ArrayList();

    Random ran = new Random();      
    int num = 0;

    for (int i = 0; i < 50; i++)
    {
        do { num = ran.Next(1, 51); } while (r.Contains(num));
        r.Add(num);
    }

    for (int i = 0; i < 50; i++)
       Console.WriteLine(r[i]);

    Console.ReadKey();
}

编辑:这将大大提高效率,防止长时间暂停等待非冲突数字:

    static void Main(string[] args)
    {
        List<int> numbers = new List<int>();

        Random ran = new Random();
        int number = 0;
        int min = 1;
        int max = 51;

        for (int i = 0; i < 50; i++)
        {
            do
            {
                number = ran.Next(min, max);
            }
            while (numbers.Contains(number));

            numbers.Add(number);

            if (number == min) min++;
            if (number == max - 1) max--;
        }

        for (int i = 0; i < 50; i++)
            Console.WriteLine(numbers[i]);

        Console.ReadKey();
    }
于 2013-10-04T10:17:30.267 回答