面试题18:树的子结构
2016-06-11 11:04
274 查看
题目:输入两颗二叉树A和B,判断B是不是A的子结构。二叉树的节点定义如下:
struct BinaryTreeNode{ int value; BinaryTreeNode* left; BinaryTreeNode* right; BinaryTreeNode(int data=int()):value(data),left(NULL),right(NULL) {} };
分析
要判断B是不是A的子结构,也就是要判断B是不是 A的子树。我们可以先遍历A,如果某一个S节点的value和B树的根节点相同,就判断S和B的左右子树是否相等,如果相等,B就是A的子结构;否则跳过S继续建立A,直到遍历完成。代码如下:
bool HasSubTree(BinaryTreeNode* root1,BinaryTreeNode* root2) { if(root1==NULL) { if(root2==NULL) return true; else return false; } if(root2==NULL) return true; if(root1->value==root2->value) { if(HasSubTree(root1->left,root2->left) && HasSubTree(root1->right,root2->right)) { return true; } else { if(HasSubTree(root1->left,root2) || HasSubTree(root1->right,root2)) { return true; } else { return false; } } } else { if(HasSubTree(root1->left,root2) || HasSubTree(root1->right,root2)) { return true; } else { return false; } } }
以上
如果你有任何想法或是可以改进的地方,欢迎和我交流!
完整代码及测试用例在github上:点我前往
相关文章推荐
- 面试题17:合并两个排序的链表
- 面试题16:反转链表
- 面试题15:链表中倒数第K个节点
- 面试题14:调整数组顺序使奇数位于偶数前面
- 面试题13:在O(1)时间 内删除链表节点
- 面试题12:打印1到最大的n位数
- 面试题11:数值的整数次方
- 记录面试需要的一些基本资料1
- 面试总结之查找算法
- Android面试题(一)
- sevice层和dao层的简单理解
- 面试题:Iterator遍历的添加删除
- [置顶] 阻碍新手程序员提升的8件小事
- 黑马程序员——Java基础---包、内部类、匿名内部类
- 假如程序员生活在童话里…
- 程序员编程的 7 + 1 条小贴士
- 一个 fork 的面试题
- java多线程常见面试题
- 《程序员修炼之道--从小工到专家》阅读笔记02
- 剑指offer面试题4 替换空格