Rumah pembangunan bahagian belakang tutorial php Bagaimana untuk menulis algoritma isihan timbunan menggunakan PHP

Bagaimana untuk menulis algoritma isihan timbunan menggunakan PHP

Jul 08, 2023 pm 07:13 PM
php algoritma Isih timbunan

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.

  1. 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:
  2. Nilai nod induk sentiasa lebih besar daripada atau sama dengan nilai nod anak (timbunan maksimum);
  3. Nilai nod induk sentiasa kurang daripada Atau sama dengan nilai nod anak (timbunan min).
  4. Melaraskan operasi timbunan
    Untuk membina timbunan, kita perlu memahami cara melakukan operasi pelarasan timbunan. Pelarasan timbunan dibahagikan kepada dua langkah:
  5. 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
  6. 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);
    }
}
Salin selepas log masuk
  1. Algoritma pengisihan timbunan
    Selepas mempunyai takrifan timbunan dan operasi pelarasan timbunan, anda boleh menulis algoritma pengisihan timbunan. Langkah utama pengisihan timbunan adalah seperti berikut:
  2. Bina timbunan maksimum: Bermula dari nod bukan daun terakhir, panggil fungsi pelarasan timbunan dalam urutan untuk membina timbunan maksimum
  3. 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
  4. 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);
    }
}
Salin selepas log masuk
  1. 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) . "
";
Salin selepas log masuk

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

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!

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Dec 24, 2024 pm 04:42 PM

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

Tarikh dan Masa CakePHP Tarikh dan Masa CakePHP Sep 10, 2024 pm 05:27 PM

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

Muat naik Fail CakePHP Muat naik Fail CakePHP Sep 10, 2024 pm 05:27 PM

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

Bincangkan CakePHP Bincangkan CakePHP Sep 10, 2024 pm 05:28 PM

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 Mencipta CakePHP Pengesah Mencipta CakePHP Sep 10, 2024 pm 05:26 PM

Pengesah boleh dibuat dengan menambah dua baris berikut dalam pengawal.

Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Dec 20, 2024 am 11:31 AM

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

Panduan Ringkas CakePHP Panduan Ringkas CakePHP Sep 10, 2024 pm 05:27 PM

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.

Bagaimana anda menghuraikan dan memproses HTML/XML dalam PHP? Bagaimana anda menghuraikan dan memproses HTML/XML dalam PHP? Feb 07, 2025 am 11:57 AM

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

See all articles