Pengedaran seragam berbanding shuffling naif?
Penyunting PHP Xiaoxin akan mendedahkan hubungan antara "pengedaran seragam dan shuffling naif". Dalam sains komputer, shuffling ialah operasi penting yang sering digunakan untuk merawak data atau koleksi. Taburan seragam bermaksud taburan nombor rawak adalah purata dalam julat tertentu. Jadi, bolehkah merombak memastikan pengedaran sekata? Jawapannya tidak mudah, jadi mari kita terokai soalan ini bersama-sama.
Kandungan soalan
Saya merombak tatasusunan 3 int sebanyak 6 juta kali. Saya merekodkan setiap pilih atur tatasusunan dalam peta. Di bawah ialah kod menggunakan go.
package main import ( "fmt" "math/rand" "time" ) func randrange(min, max int) int { return rand.intn(max-min+1) + min } func naiveshuffle(arr *[3]int) { for i := 0; i < 3; i++ { e := randrange(0, 2) arr[e], arr[i] = arr[i], arr[e] } } func main() { rand.seed(time.now().unixnano()) m := make(map[[3]int]int, 6) arr := [3]int{-6,10,184} for i := 1; i <= 6000000; i++ { a := arr naiveshuffle(&arr) m[a]++ } for k, v := range m { fmt.println(k, ":", v) } }
Memandangkan saya melakukan shuffle mudah, pemahaman saya ialah ia tidak sepatutnya tidak menghasilkan pilih atur teragih sama rata. Tetapi inilah yang saya dapat:
[184 -6 10] : 1000074 [184 10 -6] : 1000764 [-6 10 184] : 1000766 [10 184 -6] : 998090 [-6 184 10] : 1000479 [10 -6 184] : 999827
Ini menunjukkan bahawa setiap satu daripada 6 pilih atur yang mungkin berlaku kira-kira 1 juta kali. Mengapa pengedaran yang saya dapat kelihatan seragam?
EDIT: Kod ditukar kepada hanya benih sekali. Saya kini mendapat:
[-6 184 10] : 999507 [184 -6 10] : 1000401 [10 -6 184] : 1002163 [10 184 -6] : 999236 [-6 10 184] : 999016 [184 10 -6] : 999677
Sunting 2: Terima kasih kepada Hobbs, saya sedar saya melakukan kesilapan bodoh. Saya patut kocok a
,而不是 arr
. Saya kini mendapat:
[10 -6 184] : 1111056 [-6 10 184] : 888442 [184 -6 10] : 888576 [10 184 -6] : 1109896 [-6 184 10] : 1113148 [184 10 -6] : 888882
Penyelesaian
Anda mengocok arr
lebih 6 juta kali tanpa memulihkannya kepada keadaan asalnya antara shuffle - dengan kata lain, 6 juta percubaan anda tidak bebas The . Walaupun pilih atur setiap shuffle diagihkan secara tidak sekata, susun atur ini di atas satu sama lain sebanyak 6 juta kali menghasilkan taburan yang sangat hampir dengan seragam.
Atas ialah kandungan terperinci Pengedaran seragam berbanding shuffling naif?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Dengan populariti kriptografi, platform perdagangan mata wang maya telah muncul. Sepuluh platform perdagangan mata wang maya teratas di dunia disenaraikan seperti berikut mengikut jumlah transaksi dan bahagian pasaran: Binance, Coinbase, FTX, Kucoin, Crypto.com, Kraken, Huobi, Gate.io, Bitfinex, Gemini. Platform ini menawarkan pelbagai perkhidmatan, dari pelbagai pilihan cryptocurrency untuk perdagangan derivatif, sesuai untuk peniaga yang berbeza -beza.

Bagaimana cara menyesuaikan pertukaran terbuka bijan ke bahasa Cina? Tutorial ini merangkumi langkah -langkah terperinci mengenai komputer dan telefon bimbit Android, dari penyediaan awal hingga proses operasi, dan kemudian menyelesaikan masalah biasa, membantu anda dengan mudah menukar antara muka pertukaran terbuka ke Cina dan cepat memulakan dengan platform perdagangan.

Sepuluh platform perdagangan cryptocurrency teratas termasuk: 1. Okx, 2. Binance, 3. Gate.io, 4. Kraken, 5. Huobi, 6. Coinbase, 7. Kucoin, 8 crypto.com, 9. Keselamatan, kecairan, yuran pengendalian, pemilihan mata wang, antara muka pengguna dan sokongan pelanggan harus dipertimbangkan ketika memilih platform.

Platform mata wang digital yang selamat dan boleh dipercayai: 1. Okx, 2. Binance, 3. Gate.io, 4. Kraken, 5. Huobi, 6 Coinbase, 7. Kucoin, 8 crypto.com, 9. Bitfinex, 10. Keselamatan, kecairan, yuran pengendalian, pemilihan mata wang, antara muka pengguna dan sokongan pelanggan harus dipertimbangkan ketika memilih platform.

Sepuluh Platform Perdagangan Mata Wang Maya 2025: 1. Okx, 2. Binance, 3. Gate.io, 4. Kraken, 5. Huobi, 6 Coinbase, 7. Kucoin, 8. Crypto.com, 9. Keselamatan, kecairan, yuran pengendalian, pemilihan mata wang, antara muka pengguna dan sokongan pelanggan harus dipertimbangkan ketika memilih platform.

10 Perdagangan Perdagangan Mata Wang Maya Top: 1. Okx, 2. Binance, 3. Gate.io, 4. Kraken, 5. Huobi, 6 Coinbase, 7. Kucoin, 8 crypto.com, 9. Bitfinex, 10. Keselamatan, kecairan, yuran pengendalian, pemilihan mata wang, antara muka pengguna dan sokongan pelanggan harus dipertimbangkan ketika memilih platform.

Disyorkan Aplikasi Perisian Mata Wang Maya Selamat: 1. Okx, 2. Binance, 3. Gate.io, 4. Kraken, 5. Huobi, 6. Coinbase, 7. Kucoin, 8 crypto.com, 9. Bitfinex, 10. Keselamatan, kecairan, yuran pengendalian, pemilihan mata wang, antara muka pengguna dan sokongan pelanggan harus dipertimbangkan ketika memilih platform.

Jadual Kandungan Pengenalan (i) Laluan Pembelajaran (ii) Unsur-unsur Utama Perdagangan Jenis 1. Tafsiran Tingkah Laku Harga K-Line (i) Konsep Asas (ii) Alat Analisis 2 Strategi mengatasi selepas analisis trend terobosan Ringkasan Tahap Sokongan Talian Trend dan Tahap Tekanan Harga Kunci Pengenalan Tahap Tekanan
