zoukankan      html  css  js  c++  java
  • 剑指offer之【树的子结构】

    题目:

      树的子结构

    链接: 

      https://www.nowcoder.com/practice/6e196c44c7004d15b1610b9afca8bd88?tpId=13&tqId=11170&rp=1&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking

    题目描述:

      输入两棵二叉树A,B,判断B是不是A的子结构。(ps:我们约定空树不是任意一个树的子结构)

    思路:

      分为两步:

         第一步:用HasSubtree 搜索与子树根节点值相同的点(递归查找),如果找到则进行第二步。

         第二步:用isSubtree搜索子树是否是大树的子树,

    代码:

      

     1 /*
     2 struct TreeNode {
     3     int val;
     4     struct TreeNode *left;
     5     struct TreeNode *right;
     6     TreeNode(int x) :
     7             val(x), left(NULL), right(NULL) {
     8     }
     9 };*/
    10 class Solution{
    11 public:
    12     bool HasSubtree(TreeNode* pRoot1, TreeNode* pRoot2){
    13         bool result = false;
    14         if(pRoot2 == nullptr)
    15               return false;
    16         if(pRoot1 == nullptr)
    17               return false;
    18         if(pRoot1->val == pRoot2->val){
    19             result = isSubtree(pRoot1,pRoot2);
    20         }
    21         if(!result){
    22             result = HasSubtree(pRoot1->left,pRoot2)|| HasSubtree(pRoot1->right, pRoot2);
    23         }
    24         return result;
    25     }
    26     bool isSubtree(TreeNode* root1, TreeNode* root2){
    27         if(root2 == nullptr)
    28               return true;
    29         if(root1 == nullptr)
    30             return false;
    31         if(root1->val != root2->val)
    32               return false;
    33         else
    34               return isSubtree(root1->left,root2->left)&& isSubtree(root1->right,root2->right);
    35     }
    36 };

      

  • 相关阅读:
    if控制器+循环控制器+计数器,控制接口分支
    前置处理器
    逻辑控制器
    配置元件
    基础元件
    docker etcdctl报错:etcdctl No help topic for 'put'
    celery定时执行ansible api返回为空的问题
    Ansible+Jenkins+Gitlab搭建及配置
    进击的Python【第十六章】:Web前端基础之jQuery
    进击的Python【第十五章】:Web前端基础之DOM
  • 原文地址:https://www.cnblogs.com/wangshujing/p/6935462.html
Copyright © 2011-2022 走看看