[LeetCode] Invert Binary Tree 翻转二叉树
Invert a binary tree.
4 /\ 27 / \/ \ 13 69
to
4 /\ 72 / \/ \ 96 31
Trivia:
This problem was inspired by this original tweet by Max Howell:
Google: 90% of our engineers use the software you wrote (Homebrew), but you can’t invert a binary tree on a whiteboard so fuck off.两种递归的解法:
第一种 递归函数返回翻转完后的根节点
class Solution {
public TreeNode invertTree(TreeNode root) {
if(root == null)
return null;
TreeNode left = root.left;
// 后面的操作会改变 left 指针,因此先保存下来
root.left = invertTree(root.right);
root.right = invertTree(left);
return root;
}
}
第二种: 递归函数没有返回值 前序遍历调换左右节点 这个容易理解
class Solution {
public TreeNode invertTree(TreeNode root) {
invert(root);
return root;
}
private void invert(TreeNode root){
if(root == null)
return;
TreeNode node = root.left;
root.left = root.right;
root.right = node;
invert(root.left);
invert(root.right);
}
}
【leetcode刷题之 树(4)-递归:翻转树】
推荐阅读
- 数据结构与算法|【算法】力扣第 266场周赛
- leetcode|今天开始记录自己的力扣之路
- Python|Python 每日一练 二分查找 搜索旋转排序数组 详解
- 【LeetCode】28.实现strstr() (KMP超详细讲解,sunday解法等五种方法,java实现)
- LeetCode-35-搜索插入位置-C语言
- leetcode python28.实现strStr()35. 搜索插入位置
- Leetcode Permutation I & II
- python|leetcode Longest Substring with At Most Two Distinct Characters 滑动窗口法
- LeetCode 28 Implement strStr() (C,C++,Java,Python)
- Python|Python Leetcode(665.非递减数列)