


Partager une méthode de modification de tableau d'arborescence basée sur PHP
Dans le développement quotidien, nous rencontrons souvent le besoin de modifier une certaine valeur dans un tableau arborescent. Comment gérer cette situation ? Cet article partagera une méthode de modification de tableau d'arborescence basée sur PHP.
Tout d’abord, nous devons comprendre ce qu’est un tableau arborescent. Une structure arborescente fait référence à une structure de données avec des relations hiérarchiques, dans laquelle chaque nœud peut avoir zéro ou plusieurs nœuds enfants, et il peut également y avoir des relations hiérarchiques entre les nœuds enfants. En PHP, nous pouvons utiliser un tableau à deux dimensions pour représenter une structure arborescente, dans laquelle chaque nœud enfant peut être un tableau avec l'indice « enfants ».
Ce qui suit est un exemple de structure arborescente représentée par un tableau à deux dimensions :
$data = [ [ 'id' => 1, 'name' => 'A', 'children' => [ [ 'id' => 2, 'name' => 'B', 'children' => [ [ 'id' => 3, 'name' => 'C', 'children' => [ [ 'id' => 4, 'name' => 'D', 'children' => [] ] ] ] ] ] ] ] ];
Ensuite, simulons une exigence : changeons le champ de nom du nœud avec l'identifiant 3 en 'E'.
Tout d'abord, nous devons parcourir l'intégralité de l'arborescence, trouver le nœud avec l'identifiant 3 de manière récursive, puis modifier la valeur de son champ de nom. Voici le code implémenté sur la base de cette idée :
function modifyNodeValue(&$data, $id, $fieldName, $newValue) { foreach ($data as &$node) { if ($node['id'] == $id) { $node[$fieldName] = $newValue; } if (!empty($node['children'])) { modifyNodeValue($node['children'], $id, $fieldName, $newValue); } } }
La fonction ci-dessus utilise le passage de références et peut modifier directement le tableau d'origine. Nous transmettons les paramètres id, fieldName et newValue pour spécifier quel champ de quel nœud doit être modifié en quelle valeur. Son implémentation réelle consiste à parcourir chaque nœud du tableau, et lorsque le nœud avec l'identifiant spécifié est trouvé, à modifier la valeur de son champ spécifié.
Il convient de noter ici qu'en raison de la nécessité d'un parcours récursif, cette méthode peut facilement expirer ou dépasser la limite de mémoire lorsque la structure arborescente est relativement grande, elle n'est donc pas adaptée au traitement de très grandes structures arborescentes. Il peut être optimisé en divisant la grande structure arborescente en plusieurs petites structures arborescentes, puis en les modifiant séparément et enfin en les fusionnant.
Maintenant, voyons comment appeler la fonction ci-dessus pour compléter nos exemples d'exigences.
// 修改id为3的节点的name字段为'E' modifyNodeValue($data, 3, 'name', 'E'); // 输出修改后的树型结构 print_r($data);
Après avoir exécuté le code ci-dessus, vous pouvez obtenir le résultat suivant :
Array ( [0] => Array ( [id] => 1 [name] => A [children] => Array ( [0] => Array ( [id] => 2 [name] => B [children] => Array ( [0] => Array ( [id] => 3 [name] => E [children] => Array ( [0] => Array ( [id] => 4 [name] => D [children] => Array ( ) ) ) ) ) ) ) ) )
Comme vous pouvez le voir, nous avons réussi à modifier le champ de nom du nœud avec l'identifiant 3 en 'E', tout en conservant la structure de l'arborescence entière. inchangé.
Pour résumer, ce qui précède est une méthode de modification de tableau arborescent basée sur PHP. Dans le développement réel, nous pouvons choisir différentes méthodes d'optimisation en fonction des besoins spécifiques et de la taille des données pour obtenir un traitement plus efficace.
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds



Cet article détaille la mise en œuvre des files d'attente de messages en PHP à l'aide de RabbitMQ et Redis. Il compare leurs architectures (AMQP vs en mémoire), les fonctionnalités et les mécanismes de fiabilité (confirmations, transactions, persistance). Meilleures pratiques de conception, erreur

Cet article examine les normes de codage PHP actuelles et les meilleures pratiques, en se concentrant sur les recommandations PSR (PSR-1, PSR-2, PSR-4, PSR-12). Il met l'accent

Cet article explique l'API de réflexion de PHP, permettant l'inspection d'exécution et la manipulation des classes, des méthodes et des propriétés. Il détaille les cas d'utilisation courants (génération de documentation, ORMS, injection de dépendance) et prévient contre la performance Overhea

Cet article détaille l'installation et le dépannage des extensions de PHP, en se concentrant sur PECL. Il couvre les étapes d'installation (trouver, télécharger / compilation, activer, redémarrer le serveur), dépannage des techniques (vérification des journaux, vérification de l'installation,

Cet article explore l'exécution des tâches asynchrones en PHP pour améliorer la réactivité des applications Web. Il détaille des méthodes comme les files d'attente de messages, les cadres asynchrones (Reactphp, Swoole) et les processus de fond, mettant l'accent sur les meilleures pratiques pour Efficien

La compilation JIT de PHP 8 améliore les performances en compilant le code fréquemment exécuté en code machine, bénéficiant aux applications avec des calculs lourds et en réduisant les temps d'exécution.

Cet article aborde l'optimisation de la mémoire PHP. Il détaille des techniques comme l'utilisation de structures de données appropriées, d'éviter la création d'objets inutile et d'utiliser des algorithmes efficaces. Sources de fuite de mémoire communes (par exemple, connexions non clôturées, V global

Cet article explore les stratégies pour rester à jour dans l'écosystème PHP. Il met l'accent sur l'utilisation des canaux officiels, des forums communautaires, des conférences et des contributions open source. L'auteur met en évidence les meilleures ressources pour apprendre de nouvelles fonctionnalités et un
