栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

算法-翻转二叉树

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

算法-翻转二叉树

文章目录

翻转

翻转二叉树翻转等价二叉树上下翻转二叉树

翻转 翻转二叉树

翻转二叉树(简单)
先序就是自上而下的翻转
后序就是自下而上的翻转
都可以,但是不能中序!

// 将整棵树的节点翻转
TreeNode invertTree(TreeNode root) {
    // base case
    if (root == null) {
        return null;
    }

    
    // root 节点需要交换它的左右子节点
    TreeNode tmp = root.left;
    root.left = root.right;
    root.right = tmp;

    // 让左右子节点继续翻转它们的子节点
    invertTree(root.left);
    invertTree(root.right);

    return root;
}
翻转等价二叉树

添加链接描述

class Solution {
    public boolean flipEquiv(TreeNode root1, TreeNode root2) {
            if(root1==null && root2==null){
                return true;
            }
            if(root1==null || root2==null){
                return false;
            }
            if(root1.val!=root2.val){
                return false;
            }
            //不翻转 || 翻转 
            return 
            (flipEquiv(root1.left,root2.left) && flipEquiv(root1.right,root2.right)) 
            ||
             (flipEquiv(root1.left,root2.right) && flipEquiv(root1.right,root2.left));
    }
}
上下翻转二叉树

添加链接描述
思露:
首先确定:是从下往上翻转,只需考虑左子树,右子树只会有一个节点
然后:翻转之后返回新的根节点,父子树根节点是拼接在翻转之后的左子树的最右孩子节点下面的。

class Solution {
    public TreeNode upsideDownBinaryTree(TreeNode root) {
        if (root==null){
            return null;
        }
        return reverseTree(root);
    }

    private TreeNode reverseTree(TreeNode root) {
        if (root.left==null){
            return root;
        }
       
        TreeNode newRoot=reverseTree(root.left);//拿到翻转之后的左子树的根节点
        TreeNode r=newRoot;
        while (r.right!=null){ //找到左子树的最右孩子节点
            r=r.right;
        }
        r.left=root.right;
        r.right=root;
        root.left=null;
        root.right=null;
        return newRoot;
    }
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/718087.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号