How to Mirror a Binary Tree?
- 时间:2020-10-12 15:56:23
- 分类:网络文摘
- 阅读:209 次
Given a binary tree like this:
8
/ \
6 10
/ \ / \
5 7 9 11
Your task is to mirror it which becomes this:
8
/ \
10 6
/ \ / \
11 9 7 5
The most elegant algorithm to mirror a binary tree is using recursion. We can recursively mirror left and right trees respectively and then swap the left and right trees.
1 2 3 4 5 6 7 8 9 10 11 12 13 | public class Solution { public void Mirror(TreeNode root) { if (root == null) return; // make left tree also a mirror recursively Mirror(root.left); // make right tree also a mirror tree. Mirror(root.right); // swap left and right trees TreeNode t = root.left; root.left = root.right; root.right = t; } } |
public class Solution {
public void Mirror(TreeNode root) {
if (root == null) return;
// make left tree also a mirror recursively
Mirror(root.left);
// make right tree also a mirror tree.
Mirror(root.right);
// swap left and right trees
TreeNode t = root.left;
root.left = root.right;
root.right = t;
}
}The time complexity is O(N) where each node will be visited constant time, and the space complexity through calling stacks via recursion is O(N)=O(h) which is the height of the tree.
It is said that this is one of the Google’s interview question, a simple one though.
–EOF (The Ultimate Computing & Technology Blog) —
推荐阅读:如何实现微博的有效营销呢? 微博营销怎么做?看这篇就行了 微博营销如何赚钱?我给大家提供一些思路 百度AI生态的建立 给创业公司带来了什么好处? 创业项目营销效果不佳 只因没做好这几件事 AI把英语系新生吓退学?别急,我们从来都是那只懒蚂蚁 创业初期该做什么?首先你需要避开的这5大坑! 2018世界人工智能大会开幕,它给创业者带来了哪些思路? 创业寒冬下 初创公司如何才可以打破C轮死魔咒? 为什么企业找不到合适的互联网营销负责人?
- 评论列表
-
- 添加评论