这题目典型的递归题:
null
,我们返回true
。null
,一个非空,返回false
。代码如下:
public boolean isSameTree(TreeNode p, TreeNode q) {
if (p == null && q == null) {
return true;
}
if (p == null || q == null) {
return false;
}
return p.val == q.val && isSameTree(p.left, q.left) && isSameTree(p.right, q.right);
}
原题链接
这个题目,我们依旧使用递归算法。我们可以在第一题的基础上,做一个改变。
一致性代码:
return p.val == q.val && isSameTree(p.left, q.left) && isSameTree(p.right, q.right);
对称代码:
return p.val == q.val && isSameTree(p.left, q.right) && isSameTree(p.right, q.left);
最终完整代码如下:
public boolean isSymmetric(TreeNode root) {
return helper(root.left, root.right);
}
public boolean helper(TreeNode p, TreeNode q) {
if (p == null && q == null) {
return true;
}
if (p == null || q == null) {
return false;
}
return p.val == q.val && helper(p.left, q.right) && helper(p.right, q.left);
}
原题链接
此题依旧是第一题的一个进阶版,判断B
是否是A
的子树可以等同于:
A
和 B
是否相同?A.left
和 B
是否相同?A.right
和 B
是否相同?那么在第一题的基础上,我们有了函数去判断两棵树是否相等,我们只需要完成上面的判断即可:
public boolean isSubtree(TreeNode root, TreeNode subRoot) {
// 特判:root肯定不能为null
if (root == null) {
return false;
}
// 特判:subRoot子树允许为null
if (subRoot == null) {
return true;
}
return isSubtree(root.left, subRoot) || isSubtree(root.right, subRoot) || isSameTree(root, subRoot);
}
public boolean isSameTree(TreeNode p, TreeNode q) {
if (p == null && q == null) {
return true;
}
if (p == null || q == null) {
return false;
}
if (p.val != q.val) {
return false;
}
return p.val == q.val && isSameTree(p.left, q.left) && isSameTree(p.right, q.right);
}