java中的随机唯一编号

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

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); } 

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

有谁知道怎么做?

这个怎么样:

 List list = new ArrayList(number); for (int i = 0; i < number; i++) list.add(Integer.toString(i)); Collections.shuffle(list); myQueue.addAll(list); 

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

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

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

  int number = 40; Set mySet = new HashSet(); for (int j = 0; j 

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

如果有一小部分随机数,那么您可以简单地生成包含可用值的列表,并使用列表中的Collections.shuffle