gpt4 book ai didi

Java限制随机 double

转载 作者:行者123 更新时间:2023-12-01 07:35:47 27 4
gpt4 key购买 nike

我有一个简单的问题,我对随机数生成有点生疏。我想生成大的奇数整数(我使用 double ,因为我的数字可能超出 int 范围),并且我不太清楚如何消除随机数生成中的小数并使数字为奇数。

现在我只有:

N = nMin + (nMax - nMin) * rand.nextDouble();
正如我所说,这给了我 nMin 和 nMax 之间的任何随机数(带小数)。任何帮助将非常感激!

最佳答案

如果您的数字可能超出 int 范围,则应使用 long,否则应使用 BigInteger

使用 this question 中的信息创建一个随机的 BigInteger,如果它只是简单地加 1。

BigInteger randomOdd(BigInteger min, BigInteger max) {
BigInteger range = max.subtract(min);

// expected iterations: 2 - max iterations: infinite
BigInteger tmp;
do {
tmp = new BigInteger(n.bitLength(), rng); // rng is your Random Number Generator
} while (tmp.compareTo(range) >= 0);

BigInteger result = min.add(tmp);

// force the result to be odd
// TODO: will this push it over max?
result = result.or(BigInteger.ONE);

return result;
}

或者,您可以使用 BigInteger 类上的方法:BigInteger.probablePrime():

public static BigInteger probablePrime(int bitLength,
Random rnd)

Returns a positive BigInteger that is probably prime, with the specified bitLength. The probability that a BigInteger returned by this method is composite does not exceed 2^100.

Parameters:

  • bitLength - bitLength of the returned BigInteger.
  • rnd - source of random bits used to select candidates to be tested for primality.

Returns:

  • a BigInteger of bitLength bits that is probably prime

如果它可能是质数,那么它也可能是奇数。

关于Java限制随机 double ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12378326/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com