


Bagaimana untuk menulis algoritma isihan timbunan menggunakan PHP
Cara menulis algoritma pengisihan timbunan menggunakan PHP
Isihan timbunan ialah algoritma pengisihan yang cekap Idea terasnya ialah untuk membina urutan untuk diisih ke dalam timbunan binari, dan kemudian melaraskan struktur timbunan untuk mencapai pengisihan. Artikel ini akan memperkenalkan cara menulis algoritma isihan timbunan menggunakan PHP dan menyediakan contoh kod untuk rujukan.
- Definisi timbunan
Sebelum mula menulis algoritma isihan timbunan, anda perlu terlebih dahulu menjelaskan definisi dan sifat timbunan. Timbunan ialah pokok binari lengkap dengan sifat berikut: untuk mana-mana nod i, dua syarat berikut dipenuhi: - Nilai nod induk sentiasa lebih besar daripada atau sama dengan nilai nod anak (timbunan maksimum);
- Nilai nod induk sentiasa kurang daripada Atau sama dengan nilai nod anak (timbunan min).
- Melaraskan operasi timbunan
Untuk membina timbunan, kita perlu memahami cara melakukan operasi pelarasan timbunan. Pelarasan timbunan dibahagikan kepada dua langkah: - Mulakan dari nod bukan daun terakhir, bandingkan nod dengan nod anaknya secara bergilir, dan tukar nilai yang lebih besar (atau lebih kecil) kepada kedudukan nod induk
- Ulangi Langkah di atas sehingga struktur keseluruhan timbunan memenuhi sifat timbunan.
Berikut ialah contoh fungsi pelarasan timbunan yang dilaksanakan dalam PHP:
function heapify(&$arr, $n, $i) { $largest = $i; // 将当前节点标记为最大值节点 $l = 2 * $i + 1; // 左子节点 $r = 2 * $i + 2; // 右子节点 // 如果左子节点大于根节点 if ($l < $n && $arr[$l] > $arr[$largest]) { $largest = $l; } // 如果右子节点大于根节点 if ($r < $n && $arr[$r] > $arr[$largest]) { $largest = $r; } // 如果最大值不等于当前节点,则交换它们的位置 if ($largest != $i) { $temp = $arr[$i]; $arr[$i] = $arr[$largest]; $arr[$largest] = $temp; // 递归调整交换之后的子树 heapify($arr, $n, $largest); } }
- Algoritma pengisihan timbunan
Selepas mempunyai takrifan timbunan dan operasi pelarasan timbunan, anda boleh menulis algoritma pengisihan timbunan. Langkah utama pengisihan timbunan adalah seperti berikut: - Bina timbunan maksimum: Bermula dari nod bukan daun terakhir, panggil fungsi pelarasan timbunan dalam urutan untuk membina timbunan maksimum
- Isih: Tukar elemen atas (nilai maksimum ) timbunan dengan kedudukan elemen terakhir, kemudian kurangkan saiz timbunan sebanyak 1, dan kemudian panggil fungsi pelarasan timbunan untuk melaraskan susunan elemen yang tinggal
- Ulang langkah di atas sehingga saiz timbunan ialah 1; , pada masa itu semua elemen disusun dalam tertib menaik.
Berikut ialah contoh fungsi isihan timbunan yang dilaksanakan dalam PHP:
function heapSort(&$arr) { $n = count($arr); // 构建最大堆 for ($i = ($n / 2) - 1; $i >= 0; $i--) { heapify($arr, $n, $i); } // 排序 for ($i = $n - 1; $i > 0; $i--) { // 交换堆顶和最后一个元素 $temp = $arr[0]; $arr[0] = $arr[$i]; $arr[$i] = $temp; // 调整剩余元素的顺序 heapify($arr, $i, 0); } }
- Menggunakan algoritma isihan timbunan
Menggunakan algoritma isihan timbunan adalah sangat mudah Anda hanya perlu menghantar tatasusunan untuk diisih sebagai parameter fungsi isihan timbunan di atas. Berikut ialah contoh pengisihan tatasusunan menggunakan algoritma isihan timbunan:
$arr = [3, 7, 2, 11, 1, 9, 6, 4, 8]; echo "排序前:" . implode(", ", $arr) . " "; heapSort($arr); echo "排序后:" . implode(", ", $arr) . " ";
Menjalankan kod di atas, anda akan mendapat output berikut:
排序前:3, 7, 2, 11, 1, 9, 6, 4, 8 排序后:1, 2, 3, 4, 6, 7, 8, 9, 11
Dengan cara ini, kami telah berjaya menulis dan menggunakan algoritma isihan timbunan menggunakan PHP .
Ringkasan:
Isihan timbunan ialah algoritma pengisihan yang cekap yang melaksanakan pengisihan dengan membina timbunan maksimum (atau minimum). Dengan melaraskan struktur timbunan, kami boleh melaksanakan pengisihan timbunan dengan mudah. Menulis algoritma isihan timbunan menggunakan PHP adalah agak mudah Anda hanya perlu menulis fungsi pelarasan timbunan dan fungsi isihan timbunan, dan lulus tatasusunan untuk diisih sebagai parameter untuk mencapai pengisihan. Saya harap kandungan artikel ini dapat memberikan sedikit bantuan untuk anda memahami dan menggunakan algoritma isihan timbunan.
Atas ialah kandungan terperinci Bagaimana untuk menulis algoritma isihan timbunan menggunakan PHP. 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



PHP 8.4 membawa beberapa ciri baharu, peningkatan keselamatan dan peningkatan prestasi dengan jumlah penamatan dan penyingkiran ciri yang sihat. Panduan ini menerangkan cara memasang PHP 8.4 atau naik taraf kepada PHP 8.4 pada Ubuntu, Debian, atau terbitan mereka

Untuk bekerja dengan tarikh dan masa dalam cakephp4, kami akan menggunakan kelas FrozenTime yang tersedia.

Untuk mengusahakan muat naik fail, kami akan menggunakan pembantu borang. Di sini, adalah contoh untuk muat naik fail.

CakePHP ialah rangka kerja sumber terbuka untuk PHP. Ia bertujuan untuk menjadikan pembangunan, penggunaan dan penyelenggaraan aplikasi lebih mudah. CakePHP adalah berdasarkan seni bina seperti MVC yang berkuasa dan mudah difahami. Model, Pandangan dan Pengawal gu

Pengesah boleh dibuat dengan menambah dua baris berikut dalam pengawal.

Kod Visual Studio, juga dikenali sebagai Kod VS, ialah editor kod sumber percuma — atau persekitaran pembangunan bersepadu (IDE) — tersedia untuk semua sistem pengendalian utama. Dengan koleksi sambungan yang besar untuk banyak bahasa pengaturcaraan, Kod VS boleh menjadi c

CakePHP ialah rangka kerja MVC sumber terbuka. Ia menjadikan pembangunan, penggunaan dan penyelenggaraan aplikasi lebih mudah. CakePHP mempunyai beberapa perpustakaan untuk mengurangkan beban tugas yang paling biasa.

Tutorial ini menunjukkan cara memproses dokumen XML dengan cekap menggunakan PHP. XML (bahasa markup extensible) adalah bahasa markup berasaskan teks yang serba boleh yang direka untuk pembacaan manusia dan parsing mesin. Ia biasanya digunakan untuk penyimpanan data
