• 面试题18:树的子结构


    掌握这题的思路:

    第一步在树A中找到和B的根节点的值一样的节点R,第二步在判断树A中以R为根节点的子树是不是包含和树B一样的结构

     1 bool HasSubtreeCore(BinaryTreeNode* pRoot1, BinaryTreeNode* pRoot2);
     2 bool DoesTree1HaveTree2(BinaryTreeNode* pRoot1, BinaryTreeNode* pRoot2);
     3 
     4 bool HasSubtree(BinaryTreeNode* pRoot1, BinaryTreeNode* pRoot2)
     5 {
     6     bool result = false;
     7 
     8     if(pRoot1 != NULL && pRoot2 != NULL)
     9     {
    10         if(pRoot1->m_nValue == pRoot2->m_nValue)
    11             result = DoesTree1HaveTree2(pRoot1, pRoot2);
    12         if(!result)
    13             result = HasSubtree(pRoot1->m_pLeft, pRoot2);
    14         if(!result)
    15             result = HasSubtree(pRoot1->m_pRight, pRoot2);
    16     }
    17 
    18     return result;
    19 }
    20 
    21 bool DoesTree1HaveTree2(BinaryTreeNode* pRoot1, BinaryTreeNode* pRoot2)
    22 {
    23     if(pRoot2 == NULL)    //注意判断和树2相同的条件是把树2都遍历完
    24         return true;
    25 
    26     if(pRoot1 == NULL)
    27         return false;
    28 
    29     if(pRoot1->m_nValue != pRoot2->m_nValue)    //这里用!=要是用==就变得复杂了
    30         return false;
    31 
    32     return DoesTree1HaveTree2(pRoot1->m_pLeft, pRoot2->m_pLeft) &&
    33         DoesTree1HaveTree2(pRoot1->m_pRight, pRoot2->m_pRight);
    34 }
  • 相关阅读:
    ios属性或者变量的前缀-杂记
    xcode注释方法
    ios 不同的数据类型转化为json类型
    第一部分----HTML的基本结构与基本标签
    Git使用总结
    c#后台弹出框
    svn下载安装
    svn配置
    access 日期转换
    C# 中关于汉字与16进制转换的代码
  • 原文地址:https://www.cnblogs.com/raichen/p/5646103.html
Copyright © 2020-2023  润新知