Heim > Java > javaLernprogramm > ## Wie generiert man in Java zufällige BigInteger-Werte innerhalb eines bestimmten Bereichs?

## Wie generiert man in Java zufällige BigInteger-Werte innerhalb eines bestimmten Bereichs?

Mary-Kate Olsen
Freigeben: 2024-10-25 07:18:29
Original
368 Leute haben es durchsucht

## How do you generate random BigInteger values within a specific range in Java?

Zufällige BigInteger-Werte in Java generieren

In Szenarien, in denen die Generierung beliebig großer zufälliger Ganzzahlen innerhalb eines bestimmten Bereichs erforderlich ist, könnte ein gängiger Ansatz die Verwendung von nextDouble() und die Multiplikation umfassen die Ausgabe um den gewünschten Grenzwert. Diese Methode wird jedoch bei Werten über 2^53 problematisch, was zu einer ungleichmäßigen Verteilung führt.

Um diese Einschränkung zu überwinden, stellt Java die Klasse BigInteger bereit, die einen Konstruktor bietet, der Zufallszahlen generiert, die gleichmäßig zwischen 0 und verteilt sind (2^numBits - 1), einschließlich.

Erzeugen eines Zufallswerts innerhalb eines Nicht-Potenz-von-2-Bereichs

Um einen Zufallswert im Bereich 0 bis n zu generieren, wobei n keine Potenz von 2 ist, kann eine einfache Schleife verwendet werden:

<code class="java">BigInteger randomNumber;
do {
    randomNumber = new BigInteger(upperLimit.bitLength(), randomSource);
} while (randomNumber.compareTo(upperLimit) >= 0);</code>
Nach dem Login kopieren

Dieser iterative Ansatz gewährleistet eine gleichmäßige Verteilung innerhalb des gewünschten Bereichs. Normalerweise sind nur eine oder zwei Iterationen erforderlich.

Begrenzung der Iterationen in der Schleife

Für Szenarien, in denen der Zufallszahlengenerator rechenintensiv ist, kann die Anzahl der Iterationen in der Schleife wie folgt eingeschränkt werden :

<code class="java">int nlen = upperLimit.bitLength();
BigInteger nm1 = upperLimit.subtract(BigInteger.ONE);
BigInteger randomNumber, temp;
do {
    temp = new BigInteger(nlen + 100, randomSource);
    randomNumber = temp.mod(upperLimit);
} while (s.subtract(randomNumber).add(nm1).bitLength() >= nlen + 100);</code>
Nach dem Login kopieren

Es ist höchst unwahrscheinlich, dass diese modifizierte Version mehrere Iterationen erfordert (Wahrscheinlichkeit weniger als 2^100). Aufgrund der mod()-Operation entsteht jedoch ein Rechenaufwand. Daher ist es nur zu empfehlen, wenn der Zufallszahlengenerator besonders langsam ist.

Das obige ist der detaillierte Inhalt von## Wie generiert man in Java zufällige BigInteger-Werte innerhalb eines bestimmten Bereichs?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage