[算法][力扣226]翻转一颗二叉树

给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。

方式一:递归,自底向上

java 复制代码
// 反转一颗二叉树: 使用递归的方式的实现 -- 自底向上
    public TreeNode invertTree(TreeNode root) {
        // 递归跳出条件
        if (root == null) {
            return root;
        }

        // 先反转左子树
        TreeNode leftNode = invertTree(root.left);

        // 再反转右子树
        TreeNode rightNode = invertTree(root.right);

        // 再反转当前节点左右子树
        root.left = rightNode;
        root.right = leftNode;

        return root;
    }

方式二:递归,自顶向下

java 复制代码
public TreeNode invertTree2(TreeNode root) {
        TreeNode temp = root;
        doInvertTree(temp);
        return root;
    }

    // 反转一颗二叉树: 使用递归的方式的实现,自顶向下
    public void doInvertTree(TreeNode root) {
        // 递归跳出条件
        if (root == null) {
            return;
        }

        // 反转当前节点左右子树
        TreeNode tempNode = root.left;
        root.left = root.right;
        root.right = tempNode;

        // 先反转左子树
        invertTree(root.left);

        // 再反转右子树
        invertTree(root.right);
    }
相关推荐
地平线开发者5 小时前
J6B vio scenario sample
算法
BothSavage17 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn17 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽18 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说1 天前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰2 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术2 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六2 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程