本文主要是介绍245.Subtree-子树(容易题),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
子树
题目
有两个不同大小的二进制树: T1 有上百万的节点; T2 有好几百的节点。请设计一种算法,判定 T2 是否为 T1的子树。
注意事项
若 T1 中存在从节点 n 开始的子树与 T2 相同,我们称 T2 是 T1 的子树。也就是说,如果在 T1 节点 n 处将树砍断,砍断的部分将与 T2 完全相同。样例
下面的例子中 T2 是 T1 的子树:
下面的例子中 T2 不是 T1 的子树:
题解
先递归找到T1中与T2头结点相同的节点,然后再同步进行递归遍历。
/*** Definition of TreeNode:* public class TreeNode {* public int val;* public TreeNode left, right;* public TreeNode(int val) {* this.val = val;* this.left = this.right = null;* }* }*/
public class Solution {/*** @param T1, T2: The roots of binary tree.* @return: True if T2 is a subtree of T1, or false.*/public boolean isSubtree(TreeNode T1, TreeNode T2) {if (T2 == null){return true;}if (T1 == null){return false;}if (isEquals(T1,T2)){return true;}if (isSubtree(T1.left,T2) || isSubtree(T1.right,T2)){return true;}return false;}private boolean isEquals(TreeNode T1, TreeNode T2){if (T1 == null || T2 == null) {return T1 == T2;}if (T1.val != T2.val) {return false;}return isEquals(T1.left, T2.left) && isEquals(T1.right, T2.right);}
}
Last Update 2016.9.13
这篇关于245.Subtree-子树(容易题)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!