本文主要是介绍LeetCode | 572. 另一棵树的子树,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
LeetCode | 572. 另一棵树的子树
OJ链接
- 我们需要判断两棵二叉树是否相同,如果再判断的的时候不同我们就直接返回false,否则就返回true
- 然后再检查左子树和右子树里面是否存在subRoot子树~~
bool isSameTree(struct TreeNode* q, struct TreeNode* p)
{if(q == NULL && p == NULL)return true;if(q == NULL || p == NULL)return false;if(q->val != p->val)return false;return isSameTree(q->left,p->left)&& isSameTree(q->right,p->right);
}bool isSubtree(struct TreeNode* root, struct TreeNode* subRoot){if(root == NULL)return NULL;if(isSameTree(root,subRoot))return true;return isSubtree(root->left,subRoot)|| isSubtree(root->right,subRoot);
}
这篇关于LeetCode | 572. 另一棵树的子树的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!