翻转二叉树

LeetCode每日一题,226. Invert Binary Tree

先看题目描述

算法和思路

递归

这道题很简单,我们只需要从根节点开始,递归的对树进行遍历,并从叶子节点开始从下往上进行翻转即可。如果当前遍历到的节点 root 的左右两棵子树都已经翻转,那么我们只需要交换两棵子树的位置,即可完成以 root 为根节点的整棵子树的翻转

算法源码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
public TreeNode invertTree(TreeNode root) {
dfs(root);
return root;
}

private void dfs(TreeNode root) {
if (root == null) {
return;
}
dfs(root.left);
dfs(root.right);
TreeNode temp = root.right;
root.right = root.left;
root.left = temp;
}
}