力扣226. 翻转二叉树

递归

  • 思路:
    • 从根开始递归遍历二叉树,叶节点开始翻转;
    • 如果遍历到的当前的 root 节点左右两棵子树已经翻转,交换左右子树即可;
cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    TreeNode* invertTree(TreeNode* root) {
        if (root == nullptr) {
            return nullptr;
        }

        TreeNode* left = invertTree(root->left);
        TreeNode* right = invertTree(root->right);
        root->left = right;
        root->right = left;

        return root;
    }
};
相关推荐
happymaker062610 小时前
LeetCodeHot100——155.最小栈
算法
洛水水10 小时前
【力扣100题】85.每日温度
算法·leetcode·职场和发展
Coder-magician10 小时前
《代码随想录》刷题打卡day15:二叉树part05
数据结构·c++·算法
Kurisu_红莉栖10 小时前
力扣56合并区间
算法·leetcode
Darling噜啦啦10 小时前
二叉树与递归算法实战:从树结构到 LeetCode 爬楼梯,一文吃透前端数据结构与递归思维
前端·javascript·数据结构
Irissgwe10 小时前
算法的时间复杂度和空间复杂度
数据结构·c++·算法·c·时间复杂度·空间复杂度
随意起个昵称10 小时前
区间dp-基础题目3(永别)
c++·算法
周末也要写八哥10 小时前
有向图Hierholzer算法的另一种实现
算法
bIo7lyA8v10 小时前
算法调优中的性能回归与基准测试分析的技术8
算法·数据挖掘·回归
有点。10 小时前
C++贪心算法二(练习题)
c++·算法·贪心算法