Maison > développement back-end > tutoriel php > Comment implémenter le jugement de sous-structure des arbres binaires en PHP (code)

Comment implémenter le jugement de sous-structure des arbres binaires en PHP (code)

不言
Libérer: 2023-04-04 08:36:01
avant
2668 Les gens l'ont consulté

Le contenu de cet article explique comment PHP implémente le jugement de sous-structure (code) d'un arbre binaire. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.

Saisissez deux arbres binaires A et B et déterminez si B est une sous-structure de A. (ps : Nous sommes d'accord que l'arbre vide n'est une sous-structure d'aucun arbre)
1. Un sous-arbre signifie qu'il contient un nœud, et il doit contenir tous les nœuds sous ce nœud, et les deux arbres se terminent en même temps.
2. La sous-structure peut être n'importe quelle partie de l'arbre A
Idées :
1. La première récursion : deux arbres A et B. Trouvez d'abord le même point dans A que le nœud racine de B. Si la racine de A Non, puis récursez les sous-arbres gauche et droit de A pour trouver
2. La deuxième récursion : lancer la comparaison à partir des nœuds racines des deux arbres. Lors du parcours, si l'arbre B est vide, retournez. true ; si B n'est pas vide, A est vide, return false
                                                        utiliser using   using             utiliser using ‐ pour récursivement ‐ récursivement le sous-arbre gauche de A et le sous-arbre gauche de B ; récursez le sous-arbre droit de A, le sous-arbre droit de B

HasSubtree(treeA,treeB)
    if(treeA->val==treeB->val)//根结点相同
        res=tree1HasTreeB(treeA.treeB)
    if !res
        res=HasSubtree(treeA->left.treeB)//第一层遍历
    if !res
        res=HasSubtree(treeA->right.treeB)//第一层遍历
    return res
tree1HasTreeB(treeA,treeB)
    //顺序不能变
    if treeB==null  //B到底的时候,就是true
        return true
    if treeA==null
        return false//B没到底,A到底了,就是false
    if treeA->val!=treeB->val //A和B的结点没对上
        return false
    //短路语法 ,如果前面的是false,直接返回false,后面不用走
    return tree1HasTreeB(treeA->left,treeB->left)&&tree1HasTreeB(treeA->right,treeB->right)
Copier après la connexion

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!

Étiquettes associées:
php
source:cnblogs.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal