面试题19:二叉树的镜像
2016-06-11 11:05
211 查看
题目:请完成一个函数,输入一个二叉树,输出它的镜像。
二叉树的节点定义如下:struct BinaryTreeNode{ int value; BinaryTreeNode* left; BinaryTreeNode* right; BinaryTreeNode(int data=int()):value(data),left(NULL),right(NULL) {} };
分析
首先要弄明白什么是二叉树的镜像?镜像就是将二叉树的所有节点的左右指针交换后得到的二叉树。所以很容易分析出,要得到二叉树的镜像,需要交换它每个节点的左右指针。我们依次遍历该二叉树的每一个节点,交换它的左右指针,然后再交换它的左右子树即可。因此可用递归来做:
void MirrorRecursively(BinaryTreeNode* root) { if(root==NULL) return; swap(root->left,root->right); MirrorRecursively(root->left); MirrorRecursively(root->right); }
以上
如果你有任何想法或是可以改进的地方,欢迎和我交流!
完整代码及测试用例在github上:点我前往
相关文章推荐
- 面试题18:树的子结构
- 面试题17:合并两个排序的链表
- 面试题16:反转链表
- 面试题15:链表中倒数第K个节点
- 面试题14:调整数组顺序使奇数位于偶数前面
- 面试题13:在O(1)时间 内删除链表节点
- 面试题12:打印1到最大的n位数
- 面试题11:数值的整数次方
- 记录面试需要的一些基本资料1
- 面试总结之查找算法
- Android面试题(一)
- sevice层和dao层的简单理解
- 面试题:Iterator遍历的添加删除
- [置顶] 阻碍新手程序员提升的8件小事
- 黑马程序员——Java基础---包、内部类、匿名内部类
- 假如程序员生活在童话里…
- 程序员编程的 7 + 1 条小贴士
- 一个 fork 的面试题
- java多线程常见面试题
- 《程序员修炼之道--从小工到专家》阅读笔记02