生成比前一个随机数更大或更小的随机数

Sam*_*ell 5 java random math int inequality

我试图生成一个大于和小于前一个随机数的随机数,但不知道如何生成。

到目前为止我有这个:

number = (int)( max * Math.random() ) + min;
guess = (int)( max * Math.random() ) + min;
if (guess<number)
   {
      guess = (int)( max * Math.random() ) + min;
      System.out.println(guess);
    }
else if (guess>number)
 {
      guess = (int)( max * Math.random() ) + min;
     System.out.println(guess);
 }
Run Code Online (Sandbox Code Playgroud)

更新:如何确保它不会生成已经生成的随机数?计算机会尝试 10 次猜测生成的数字,但我想让它合乎逻辑,不会生成它已经知道是错误的数字。

Maa*_*wes 3

订购一个随机数列表怎么样?

public static void method2() throws Exception {
    Random rng = new SecureRandom();
    Set<Integer> numbers = new HashSet<>();
    while (numbers.size() < 3) {
        // number only added if not already present in Set, set values are unique
        numbers.add(rng.nextInt(MAX));
    }
    List<Integer> numberList = new ArrayList<>(numbers);
    Collections.sort(numberList);
    // lower random at index 0, mid at index 1
    // you can guess where the other one is hiding 
    System.out.println(numberList);
}
Run Code Online (Sandbox Code Playgroud)

我首先将它们放在一组中以确保没有重复。当然,如果MAX值为 1,这可能需要一段时间。

这种方法的一个优点是数字应该很好地分布在 0 到 MAX 之间。如果直接使用范围,则必须处理上限和下限。

当然,只要值的最大数量(显着)高于列表中的数字数量(在本例中仅为 3),这种方法就可以轻松扩展到在范围内工作。