[C++]LeetCode226. 翻转二叉树

226. 翻转二叉树
思路:交换两个节点,接着递归左孩子和右孩子

题目:翻转一棵二叉树。

示例:
输入:

 4

/
2 7
/ \ /
1 3 6 9
输出:
4
/
7 2
/ \ /
9 6 3 1

class Solution {
public:
    TreeNode* invertTree(TreeNode* root) {
        if (root == NULL) return root;
        swap(root->left, root->right);
        invertTree(root->left);
        invertTree(root->right);
        return root;
    }
};

时间复杂度:O(N)

空间复杂度:O(N)

[[C++]Leetcode超高效刷题顺序及题目详解笔记(持续更新中)]

你可能感兴趣的:(Leetcode刷题,c++,数据结构)