Rumah pembangunan bahagian belakang masalah PHP Mari kita bincangkan tentang cara menukar tatasusunan dua dimensi kepada struktur pokok dalam PHP

Mari kita bincangkan tentang cara menukar tatasusunan dua dimensi kepada struktur pokok dalam PHP

Apr 12, 2023 pm 01:57 PM

Dengan pembangunan berterusan aplikasi rangkaian, semakin banyak tapak web dan aplikasi dibangunkan menggunakan pemisahan bahagian hadapan dan belakang. Ini memisahkan kod bahagian hadapan daripada kod bahagian belakang dan memerlukan komunikasi melalui interaksi data. Dalam proses interaksi data, tatasusunan sering digunakan, terutamanya tatasusunan dua dimensi. Jadi bagaimana untuk menukar tatasusunan dua dimensi ke dalam struktur pokok? Artikel ini akan berkongsi cara menukar tatasusunan dua dimensi kepada pokok dalam PHP.

1. Apakah itu struktur pokok

Sebelum memperkenalkan cara menukar tatasusunan dua dimensi kepada bentuk pokok, mari kita fahami dahulu apa itu struktur pokok. Dalam sains komputer, struktur pepohon ialah struktur data tak linear, yang merupakan satu set perhubungan hierarki yang terdiri daripada n (n>0) nod terhad. Salah satu nod dipanggil nod akar, dan nod yang tinggal boleh dilihat sebagai satu atau lebih subpokok struktur pokok.

Mari kita lihat contoh mudah Sebagai contoh, struktur organisasi syarikat boleh dipaparkan sebagai struktur pokok Peringkat teratas ialah pengurus besar (nod akar), dan terdapat beberapa pengurus jabatan (sub-nod ) di bawah Setiap Terdapat beberapa pekerja (nod daun) di bawah pengurus jabatan.

2. Prinsip menukar tatasusunan dua dimensi kepada struktur pokok

Menukar tatasusunan dua dimensi kepada struktur pokok boleh dianggap sebagai satu set data rata, menggunakan dalamannya perhubungan untuk menukar Proses menyusunnya menjadi struktur data pokok. Proses penukaran boleh dilaksanakan secara rekursif. Langkah-langkah khusus adalah seperti berikut:

  1. Cari data nod akar daripada tatasusunan dua dimensi, keluarkannya daripada tatasusunan, dan kemudian cari nod anak secara rekursif. di bawah nod akar.
  2. Lintasi keseluruhan tatasusunan, tolak nod anak dalam setiap elemen ke dalam tindanan, dan kemudian cari nod anak di bawah nod anak secara rekursif.
  3. Keadaan akhir rekursif ialah tatasusunan semasa kosong atau tiada nod anak nod semasa.

Mengikut tiga langkah di atas, fungsi menukar tatasusunan dua dimensi kepada pokok boleh direalisasikan.

3. Pelaksanaan Kod

Di bawah ini kami menggunakan contoh praktikal untuk menunjukkan cara menukar tatasusunan dua dimensi kepada struktur pokok. Katakan kita mempunyai tatasusunan dua dimensi berikut:

$data = array(
    array('id'=>1,'name'=>'节点1','pid'=>0),
    array('id'=>2,'name'=>'节点2','pid'=>1),
    array('id'=>3,'name'=>'节点3','pid'=>2),
    array('id'=>4,'name'=>'节点4','pid'=>2),
    array('id'=>5,'name'=>'节点5','pid'=>0)
);
Salin selepas log masuk

Tatasusunan ini mengandungi 5 nod, dengan id mewakili pengecam unik nod, nama mewakili nama nod dan pid mewakili id ​​nod induk nod.

Kini kita perlu menukar tatasusunan dua dimensi ini kepada struktur pokok berikut:

Array
(
    [0] => Array
        (
            [id] => 1
            [name] => 节点1
            [children] => Array
                (
                    [0] => Array
                        (
                            [id] => 2
                            [name] => 节点2
                            [children] => Array
                                (
                                    [0] => Array
                                        (
                                            [id] => 3
                                            [name] => 节点3
                                            [children] => Array()
                                        )

                                    [1] => Array
                                        (
                                            [id] => 4
                                            [name] => 节点4
                                            [children] => Array()
                                        )

                                )

                        )

                )

        )

    [1] => Array
        (
            [id] => 5
            [name] => 节点5
            [children] => Array()
        )

)
Salin selepas log masuk

Proses pelaksanaan khusus adalah seperti berikut:

function buildTree(&$data,$pid = 0){
    $tree = array();
    foreach($data as $k=>$v){
        if($v['pid'] == $pid){
            $temp = $v;
            $temp['children'] = buildTree($data,$v['id']);
            $tree[] = $temp;
            unset($data[$k]);
        }
    }
    return $tree;
}

$data =    array(
    array('id'=>1,'name'=>'节点1','pid'=>0),
    array('id'=>2,'name'=>'节点2','pid'=>1),
    array('id'=>3,'name'=>'节点3','pid'=>2),
    array('id'=>4,'name'=>'节点4','pid'=>2),
    array('id'=>5,'name'=>'节点5','pid'=>0)
);
print_r(buildTree($data));
Salin selepas log masuk

Dalam kod di atas, buildTree Fungsi mula-mula membuat tatasusunan kosong $tree, kemudian melintasi keseluruhan tatasusunan $data, menyimpan semua data dengan pid $pid ke dalam tatasusunan $tree, dan secara rekursif mencari semua nod anak di bawah $pid, dan kemudian mengembalikan $tree array. Jika tatasusunan $data kosong atau tiada nod anak nod semasa, rekursi tamat.

4. Ringkasan

Melalui kod di atas, kita dapat melihat bahawa proses menukar tatasusunan dua dimensi kepada struktur pokok adalah sangat mudah nod mengikut urutan. Hanya menyusunnya ke dalam struktur pokok. Ini sangat berguna untuk pemprosesan dan paparan data dalam pembangunan web, dan boleh merealisasikan fungsi paparan data dan organisasi struktur data yang berbeza dalam senario yang berbeza.

Atas ialah kandungan terperinci Mari kita bincangkan tentang cara menukar tatasusunan dua dimensi kepada struktur pokok dalam 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
4 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)

PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. Mar 25, 2025 am 10:37 AM

Kompilasi JIT Php 8 meningkatkan prestasi dengan menyusun kod yang sering dilaksanakan ke dalam kod mesin, memberi manfaat kepada aplikasi dengan pengiraan berat dan mengurangkan masa pelaksanaan.

PHP Secure File Muat naik: Mencegah kelemahan berkaitan fail. PHP Secure File Muat naik: Mencegah kelemahan berkaitan fail. Mar 26, 2025 pm 04:18 PM

Artikel ini membincangkan mendapatkan muat naik fail PHP untuk mengelakkan kelemahan seperti suntikan kod. Ia memberi tumpuan kepada pengesahan jenis fail, penyimpanan selamat, dan pengendalian ralat untuk meningkatkan keselamatan aplikasi.

OWASP Top 10 PHP: Huraikan dan mengurangkan kelemahan umum. OWASP Top 10 PHP: Huraikan dan mengurangkan kelemahan umum. Mar 26, 2025 pm 04:13 PM

Artikel ini membincangkan kelemahan OWASP 10 dalam strategi PHP dan mitigasi. Isu -isu utama termasuk suntikan, pengesahan yang rosak, dan XSS, dengan alat yang disyorkan untuk memantau dan mendapatkan aplikasi PHP.

Penyulitan PHP: Penyulitan simetri vs asimetrik. Penyulitan PHP: Penyulitan simetri vs asimetrik. Mar 25, 2025 pm 03:12 PM

Artikel ini membincangkan penyulitan simetri dan asimetrik dalam PHP, membandingkan kesesuaian, prestasi, dan perbezaan keselamatan mereka. Penyulitan simetri lebih cepat dan sesuai untuk data pukal, manakala asimetrik digunakan untuk pertukaran utama yang selamat.

Pengesahan PHP & amp; Kebenaran: Pelaksanaan selamat. Pengesahan PHP & amp; Kebenaran: Pelaksanaan selamat. Mar 25, 2025 pm 03:06 PM

Artikel ini membincangkan pelaksanaan pengesahan dan kebenaran yang mantap dalam PHP untuk mencegah akses yang tidak dibenarkan, memperincikan amalan terbaik dan mengesyorkan alat peningkatan keselamatan.

Bagaimana anda mengambil data dari pangkalan data menggunakan PHP? Bagaimana anda mengambil data dari pangkalan data menggunakan PHP? Mar 20, 2025 pm 04:57 PM

Artikel membincangkan mendapatkan data dari pangkalan data menggunakan PHP, meliputi langkah, langkah keselamatan, teknik pengoptimuman, dan kesilapan umum dengan penyelesaian.

PHP API Kadar Mengehadkan: Strategi Pelaksanaan. PHP API Kadar Mengehadkan: Strategi Pelaksanaan. Mar 26, 2025 pm 04:16 PM

Artikel ini membincangkan strategi untuk melaksanakan kadar API yang mengehadkan PHP, termasuk algoritma seperti baldi token dan baldi bocor, dan menggunakan perpustakaan seperti simfoni/kadar-limiter. Ia juga meliputi pemantauan, had kadar penyesuaian secara dinamik, dan tangan

PHP CSRF Perlindungan: Bagaimana untuk mencegah serangan CSRF. PHP CSRF Perlindungan: Bagaimana untuk mencegah serangan CSRF. Mar 25, 2025 pm 03:05 PM

Artikel ini membincangkan strategi untuk mencegah serangan CSRF di PHP, termasuk menggunakan token CSRF, kuki tapak yang sama, dan pengurusan sesi yang betul.

See all articles