Rumah > Java > javaTutorial > Bagaimana untuk Menjana Integer Besar Rawak Sewenang-wenangnya dalam Julat Tertentu di Jawa?

Bagaimana untuk Menjana Integer Besar Rawak Sewenang-wenangnya dalam Julat Tertentu di Jawa?

Linda Hamilton
Lepaskan: 2024-10-25 01:02:30
asal
525 orang telah melayarinya

How to Generate Arbitrarily Large Random BigIntegers in a Specific Range in Java?

Menjana Integer Besar Rawak dalam Java

Soalan:

Bagaimana anda menjana rawak besar secara sewenang-wenangnya Nilai BigInteger dalam julat 0 hingga n (tidak termasuk n), di mana n bukan kuasa 2?

Jawapan:

Menggunakan pembina BigInteger yang memerlukan sedikit masa kiraan dan contoh penjana Rawak, anda boleh mencipta nilai sedemikian:

public BigInteger(int numBits, Random rnd)
Salin selepas log masuk

Walau bagaimanapun, untuk mendapatkan nilai dalam julat yang dikehendaki, perlu menggunakan gelung:

BigInteger randomNumber;
do {
    randomNumber = new BigInteger(upperLimit.bitLength(), randomSource);
} while (randomNumber.compareTo(upperLimit) >= 0);
Salin selepas log masuk

Secara purata, gelung ini beroperasi dalam kurang daripada dua lelaran, memastikan pengedaran seragam.

Edit:

Untuk situasi di mana penjana Rawak adalah intensif prestasi, anda boleh laksanakan pendekatan berikut:

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);
Salin selepas log masuk

Walaupun kaedah ini mengurangkan dengan ketara kemungkinan lelaran berbilang gelung (kurang daripada satu peluang dalam 2^100), ia menggunakan operasi mod() yang mahal secara pengiraan. Oleh itu, pendekatan ini mungkin kurang cekap berbanding yang sebelumnya jika contoh Rawak yang dibekalkan mempunyai overhed prestasi rendah.

Atas ialah kandungan terperinci Bagaimana untuk Menjana Integer Besar Rawak Sewenang-wenangnya dalam Julat Tertentu di Jawa?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan