【LeetCode】226. 翻转二叉树
题目描述
难度:【简单】
标签:【二叉树】
翻转一棵二叉树。
题目地址:https://leetcode-cn.com/problems/invert-binary-tree/
示例
输入
4
/ \
2 7
/ \ / \
1 3 6 9
输出
4
/ \
7 2
/ \ / \
9 6 3 1
题目大意
翻转一棵二叉树。
解题
从示例中可以看出,要翻转一颗二叉树,站在节点的角度,就是把这个节点的左右子节点做个交换。
先做好交换的处理,然后根节点的左右子树进行递归,继续重复这个动作。
另外,考虑传入的节点为空的情况,直接返回 null 。
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode() {}
* TreeNode(int val) { this.val = val; }
* TreeNode(int val, TreeNode left, TreeNode right) {
* this.val = val;
* this.left = left;
* this.right = right;
* }
* }
*/
class Solution {
public TreeNode invertTree(TreeNode root) {
if (root == null) {
return null;
}
// 利用一个临时节点,交换左右节点
TreeNode temp = root.left;
root.left = root.right;
root.right = temp;
invertTree(root.left);
invertTree(root.right);
return root;
}
}
--不要用肉体的勤奋,去掩盖思考的懒惰--