Bagaimana untuk melaksanakan algoritma isihan timbunan menggunakan java
Cara melaksanakan algoritma isihan timbunan dalam Java
Isihan timbunan ialah algoritma isihan berdasarkan struktur data timbunan, yang mengambil kesempatan daripada sifat timbunan untuk mengisih. Isih timbunan dibahagikan kepada dua langkah utama: membina timbunan dan isihan.
Membina timbunan:
Pertama, kita perlu membina timbunan akar yang besar atau timbunan akar yang kecil berdasarkan tatasusunan yang hendak diisih. Untuk jenis menaik, kita perlu membina timbunan akar yang besar;
Harta timbunan akar yang besar ialah: nilai nod lebih besar daripada atau sama dengan nilai nod anaknya.
Harta timbunan akar kecil ialah: nilai nod adalah kurang daripada atau sama dengan nilai nod anaknya.
Proses membina timbunan akar yang besar adalah seperti berikut:
public static void buildHeap(int[] array, int length) { for (int i = length / 2 - 1; i >= 0; i--) { heapify(array, length, i); } } public static void heapify(int[] array, int length, int i) { int largest = i; int left = 2 * i + 1; int right = 2 * i + 2; if (left < length && array[left] > array[largest]) { largest = left; } if (right < length && array[right] > array[largest]) { largest = right; } if (largest != i) { int temp = array[i]; array[i] = array[largest]; array[largest] = temp; heapify(array, length, largest); } }
Isih:
Selepas membina timbunan akar yang besar, kita perlu menukar elemen atas timbunan dengan elemen terakhir tatasusunan, dan mengurangkan skop timbunan, dan kemudian lakukan operasi timbunan pada timbunan , ulangi proses ini sehingga timbunan kosong. Tatasusunan akhir dipesan.
public static void heapSort(int[] array) { int length = array.length; buildHeap(array, length); for (int i = length - 1; i >= 0; i--) { int temp = array[i]; array[i] = array[0]; array[0] = temp; heapify(array, i, 0); } }
Contoh penggunaan:
public static void main(String[] args) { int[] array = {4, 10, 3, 5, 1}; heapSort(array); System.out.println(Arrays.toString(array)); }
Hasil keluaran ialah: [1, 3, 4, 5, 10], iaitu hasil isihan menaik.
Kerumitan masa isihan timbunan ialah O(nlogn), dengan n ialah bilangan elemen untuk diisih. Isihan timbunan ialah algoritma pengisihan yang stabil sesuai untuk mengisih data berskala besar.
Atas ialah kandungan terperinci Bagaimana untuk melaksanakan algoritma isihan timbunan menggunakan java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Artikel ini membincangkan menggunakan Maven dan Gradle untuk Pengurusan Projek Java, membina automasi, dan resolusi pergantungan, membandingkan pendekatan dan strategi pengoptimuman mereka.

Artikel ini membincangkan membuat dan menggunakan perpustakaan Java tersuai (fail balang) dengan pengurusan versi dan pergantungan yang betul, menggunakan alat seperti Maven dan Gradle.

Artikel ini membincangkan pelaksanaan caching pelbagai peringkat di Java menggunakan kafein dan cache jambu untuk meningkatkan prestasi aplikasi. Ia meliputi persediaan, integrasi, dan faedah prestasi, bersama -sama dengan Pengurusan Dasar Konfigurasi dan Pengusiran PRA Terbaik

Artikel ini membincangkan menggunakan JPA untuk pemetaan objek-relasi dengan ciri-ciri canggih seperti caching dan pemuatan malas. Ia meliputi persediaan, pemetaan entiti, dan amalan terbaik untuk mengoptimumkan prestasi sambil menonjolkan potensi perangkap. [159 aksara]

Kelas kelas Java melibatkan pemuatan, menghubungkan, dan memulakan kelas menggunakan sistem hierarki dengan bootstrap, lanjutan, dan pemuat kelas aplikasi. Model delegasi induk memastikan kelas teras dimuatkan dahulu, yang mempengaruhi LOA kelas tersuai


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

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma