首頁 > 後端開發 > php教程 > 如何在PHP中將父子關係轉換為層次樹?

如何在PHP中將父子關係轉換為層次樹?

Linda Hamilton
發布: 2024-12-26 09:57:10
原創
462 人瀏覽過

How to Convert Parent-Child Relationships into Hierarchical Trees in PHP?

將父子關係轉換為層次樹

在程式設計中,可能需要將一系列的父子關係轉換為層次樹層次樹結構。此任務可以使用遞歸方法在 PHP 中完成。

範例資料:

考慮下列一組父子關係:

Child : Parent
H : G
F : G
G : D
E : D
A : E
B : C
C : E
D : NULL
登入後複製

轉換為層次結構樹:

為了將此資料轉換為分層樹結構,我們建立兩個PHP函數:

  • parseTree($tree, $root) :此函式遞歸地解析子父對並建構tree.
  • printTree($tree):函數遍歷樹並將其列印為無序列表。

parseTree 函數:

function parseTree($tree, $root = null) {
    $return = array();
    foreach($tree as $child => $parent) {
        if($parent == $root) {
            unset($tree[$child]);
            $return[] = array(
                'name' => $child,
                'children' => parseTree($tree, $child)
            );
        }
    }
    return empty($return) ? null : $return;    
}
登入後複製

printTree函數:

function printTree($tree) {
    if(!is_null($tree) && count($tree) > 0) {
        echo '<ul>';
        foreach($tree as $node) {
            echo '<li>' . $node['name'];
            printTree($node['children']);
            echo '</li>';
        }
        echo '</ul>';
    }
}
登入後複製

用法:

要使用這些函數,首先初始化子父對數組。然後使用陣列呼叫parseTree 並使用產生的樹呼叫printTree

$tree = array(
    'H' => 'G',
    'F' => 'G',
    'G' => 'D',
    'E' => 'D',
    'A' => 'E',
    'B' => 'C',
    'C' => 'E',
    'D' => null
);

$result = parseTree($tree);
printTree($result);
登入後複製

結果:

結果:
<ul>
<li>D
<ul>
<li>G
<ul>
<li>H</li>
<li>F</li>
</ul>
</li>
<li>E
<ul>
<li>A</li>
<li>C
<ul>
<li>B</li>
</ul>
</li>
</ul>
</li>
</ul>
</li>
</ul>
登入後複製
結果:結果:結果:結果:結果將🎜>將是表示層次樹的無序列表:

以上是如何在PHP中將父子關係轉換為層次樹?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板