2

我正在尝试获取随机数列表并将其放入队列中,而不会重复随机数。

        int number = 40;

        for (int j = 0; j<number; j++)
        {
            int pick = random.nextInt(number);
            myQueue.add(Integer.toString(pick));
        }
        System.out.println("the queue size: "+myQueue.size());
        Iterator it = myQueue.iterator();
        while(it.hasNext()){
                String iteratorValue = (String)it.next();
                System.out.println("queue next value: "+iteratorValue);
        }

使用上面的代码,我得到了一些随机数的重复

有谁知道怎么做??

4

3 回答 3

8

这个怎么样:

List<String> list = new ArrayList<String>(number);

for (int i = 0; i < number; i++)
    list.add(Integer.toString(i));

Collections.shuffle(list);

myQueue.addAll(list);

在某个范围内“添加唯一随机数”相当于将该范围内的所有数字相加,然后对结果进行洗牌。

于 2013-01-05T18:44:10.657 回答
3

创建一个集合并在生成它们时将它们添加到其中。每次生成新数字时,请检查 Set 是否已包含该值。继续生成新数字并检查集合,直到找到不存在的数字。

沿着这些思路......(请注意,Set.add(...)如果值已经在 Set 中,则返回 false,因此 do-while 循环将继续,直到生成唯一的数字。)

   int number = 40;
   Set mySet = new HashSet();
   for (int j = 0; j<number; j++)
   {
       Integer pick;

       do{
           pick = random.nextInt(number);
       } while(!mySet.add(pick));
       myQueue.add(Integer.toString(pick));
   }
   System.out.println("the queue size: "+myQueue.size());
   Iterator it = myQueue.iterator();
   while(it.hasNext()){
           String iteratorValue = (String)it.next();
           System.out.println("queue next value: "+iteratorValue);
   }

尽管如 ARS 所述,您似乎不是在寻找一个随机的唯一数字,而是在 0 到 40 之间的所有数字的随机打乱列表。如果是这种情况,请使用他/她的解决方案,因为它是更好的方式来实现这一目标。

于 2013-01-05T18:43:45.040 回答
0

如果随机数的范围很小,那么您可以简单地生成具有可用值的列表并Collections.shuffle在列表上使用。

于 2013-01-05T18:45:34.543 回答