Bagaimana untuk mengisih 100 juta nombor rawak di Jawa?
1. Isih sisipan langsung
1. Isih sisipan bergambar
Idea: Secara harfiah, sisipan ialah meletakkan elemen ke tempat tertentu mengikut peraturan tertentu. dalam set, jadi kita perlu membahagikan urutan itu kepada dua bahagian, satu bahagian ialah set tersusun, dan bahagian lain ialah set yang hendak diisih
Ilustrasi:
Untuk memudahkan pemahaman, kami akan mengambil urutan 4321 yang paling istimewa sebagai contoh
Mengikut idea di atas, kita perlu membahagikan urutan tersebut kepada dua bahagian. . Untuk kemudahan pengekodan, kami akan membahagikan yang pertama kepada dua bahagian dengan mengandaikan bahawa elemen adalah set tersusun, maka gelung kami harus bermula dari elemen kedua , iaitu 3
Untuk mengelak daripada menulis ganti 3 dalam operasi seterusnya, kami memilih Pembolehubah sementara untuk menyimpan 3. Iaitu, val=arr[1]
di atas,
Memandangkan kami beroperasi pada tatasusunan, kami juga perlu mendapatkan indeks elemen terakhir yang dipesan ditetapkan sebagai kursor
Apabila kursor tidak melintasi sempadan dan nilai yang hendak disisipkan adalah kurang daripada kedudukan yang ditunjukkan oleh kursor (4 dalam gambar di atas), kita gerakkan elemen 4 ke belakang, gerakkan kursor ke hadapan, dan terus semak koleksi Adakah elemen lain dalam set lebih kecil daripada elemen yang akan dimasukkan, sehingga kursor melintasi sempadan
Dalam angka di atas, kerana terdapat hanya satu 4 dalam set, kursor bergerak ke hadapan dan melintasi sempadan, jadi gelung itu berakhir
public static void insertSort(int[]arr){ for(int i = 1 ; i < arr.length; i++){ int val = arr[i]; int valIndex = i - 1; //游标 while(valIndex >= 0 && val < arr[valIndex]){ //插入的值比游标指示的值小 arr[valIndex + 1] = arr[valIndex]; valIndex--; //游标前移 } arr[valIndex+1] = val; } } 1234567891011
3. Ujian prestasi dan kerumitan ruang masa
Ia sebenarnya mengambil masa 1 minit dan 4 saat untuk menjalankan 800,000 keping data (bukan nilai yang tepat, setiap mesin mungkin berbeza) )< .
Bilangan perbandingan kata kunci:Jumlah bilangan pergerakan:
Jadi kerumitan masa adalah kira-kira
1. Ilustrasi idea
KCN=(n^2)/2
RMN= (n^2)/2
2. Pelaksanaan kod
public static void shellSort(int[] arr){ //交换法 int tmp = 0; for(int gap = arr.length / 2 ; gap > 0 ; gap /= 2){ for(int i = gap ; i < arr.length ; i++){ //先遍历所有数组 for(int j = i - gap ; j >= 0 ; j -= gap){//开启插入排序 if(arr[ j ] > arr[ gap + j ]){ //可以根据升降序修改大于或小于 tmp = arr[gap + j]; arr[j+gap] = arr[j]; arr[j] = tmp; } } } System.out.println(gap); System.out.println(Arrays.toString(arr)); } } 12345678910111213141516
Perkara yang paling sukar untuk difahami di sini ialah yang ketiga untuk Gelung, O(N^2)
, mewakili elemen pertama dalam kumpulan, iaitu,
ialah klasifikasi logik , indeks bagi elemen kedua hendaklah semua nilai elemen pertama + jurang tambahan
), tukar dua, jika tidak, teruskan membandingkan atau melompat keluar dari gelung,
), dan kemudian teruskan langkah di atas sehingga jurang kenaikan ialah 1, pengisihan jujukan tamat
3 Kerumitan masa j = i - gap
j=0
H Kerumitan masa pengisihan Er bergantung pada fungsi
, yang memerlukan analisis khusus masalah khusus dan bukan nilai yang pasti Ini juga merupakan perkara keempat yang perlu dibincangkan 4 pemilihan kenaikan, Ia adalah masalah yang tidak dapat diselesaikan dalam matematik j-=gap
, kerumitan masa boleh dikurangkan kepada: gap/=2
Dalam perkara seterusnya, dalam kaedah anjakan, kami juga telah melakukan beberapa eksperimen Kami boleh memastikan bahawa untuk pengiraan dalam skala tertentu (. seperti 800w~100 juta),
Bukit Kelajuan pengisihan jauh lebih cepat daripada pengisihan timbunan, sekurang-kurangnya pada komputer saya
3. Pengisihan bukit (kaedah anjakan) Kaedah pertukaran lebih cepat daripada kaedah anjakan Kaedah bit adalah jauh lebih perlahan, jadi kaedah anjakan gap/=2
lebih biasa digunakan, dan kaedah anjakan lebih "seperti" jenis sisipan
1. Berbanding dengan kaedah swap, kaedah anjakan n->无穷大
pengumpulan dan
. . Kecekapan adalah sangat tinggi. merangkumi mata. >2. Pelaksanaan kod
public static void shellSort02(int[] arr){ //移位法 for(int gap = arr.length/2 ; gap > 0 ; gap /= 2){ //分组 for(int i = gap ; i < arr.length ; i++){ //遍历 int valIndex = i; int val = arr[valIndex]; if(val < arr[valIndex-gap]){ //插入的值小于组内另一个值 while(valIndex - gap >=0 && val < arr[valIndex-gap]){ //开始插排 // 插入 arr[valIndex] = arr[valIndex-gap]; valIndex -= gap; //让valIndex = valIndex-gap (游标前移) } } arr[valIndex] = val; } } } 12345678910111213141516
3.
Atas ialah kandungan terperinci Bagaimana untuk mengisih 100 juta nombor rawak di Jawa?. 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

Panduan untuk Square Root di Java. Di sini kita membincangkan cara Square Root berfungsi di Java dengan contoh dan pelaksanaan kodnya masing-masing.

Panduan Nombor Sempurna di Jawa. Di sini kita membincangkan Definisi, Bagaimana untuk menyemak nombor Perfect dalam Java?, contoh dengan pelaksanaan kod.

Panduan untuk Penjana Nombor Rawak di Jawa. Di sini kita membincangkan Fungsi dalam Java dengan contoh dan dua Penjana berbeza dengan contoh lain.

Panduan untuk Weka di Jawa. Di sini kita membincangkan Pengenalan, cara menggunakan weka java, jenis platform, dan kelebihan dengan contoh.

Panduan untuk Nombor Armstrong di Jawa. Di sini kita membincangkan pengenalan kepada nombor Armstrong di java bersama-sama dengan beberapa kod.

Panduan untuk Nombor Smith di Jawa. Di sini kita membincangkan Definisi, Bagaimana untuk menyemak nombor smith di Jawa? contoh dengan pelaksanaan kod.

Dalam artikel ini, kami telah menyimpan Soalan Temuduga Spring Java yang paling banyak ditanya dengan jawapan terperinci mereka. Supaya anda boleh memecahkan temuduga.

Java 8 memperkenalkan API Stream, menyediakan cara yang kuat dan ekspresif untuk memproses koleksi data. Walau bagaimanapun, soalan biasa apabila menggunakan aliran adalah: bagaimana untuk memecahkan atau kembali dari operasi foreach? Gelung tradisional membolehkan gangguan awal atau pulangan, tetapi kaedah Foreach Stream tidak menyokong secara langsung kaedah ini. Artikel ini akan menerangkan sebab -sebab dan meneroka kaedah alternatif untuk melaksanakan penamatan pramatang dalam sistem pemprosesan aliran. Bacaan Lanjut: Penambahbaikan API Java Stream Memahami aliran aliran Kaedah Foreach adalah operasi terminal yang melakukan satu operasi pada setiap elemen dalam aliran. Niat reka bentuknya adalah
