Construire un arbre à partir d'un tableau plat en PHP
En PHP, il peut être difficile de construire une structure de données arborescente à partir d'un tableau plat . Cependant, cette tâche peut être simplifiée en appliquant la récursion et une compréhension de la relation parent-enfant au sein du tableau plat.
Étant donné un tableau plat où chaque élément a un « id » et un « parent_id », l'objectif est de le convertir en un arbre hiérarchique. Chaque élément de l'arbre résultant doit avoir une propriété « enfants » s'il contient des éléments enfants.
Solution
Le code fourni tente de créer l'arbre de manière récursive, mais il ne parvient pas à supprimer l'élément après l'avoir ajouté à la branche, ce qui entraîne plusieurs copies du même élément. Pour résoudre ce problème, nous devons supprimer l'élément du tableau plat après l'avoir ajouté à la branche.
function buildTree(array &$elements, $parentId = 0) { $branch = array(); foreach ($elements as $element) { if ($element['parent_id'] == $parentId) { $children = buildTree($elements, $element['id']); if ($children) { $element['children'] = $children; } $branch[$element['id']] = $element; unset($elements[$element['id']]); } } return $branch; }
Explication
Le tableau résultant sera un arbre hiérarchique avec chaque nœud contenant ses enfants sous forme de tableau imbriqué, fournissant une représentation claire des relations parent-enfant dans le tableau plat d'origine.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!