人类的......呃,不是。翻转二叉树的本质是什么?

78 篇文章 0 订阅

让我们来看LeetCode上的这个实例

在这里插入图片描述
可以看出,其本质就是交换每个结点的左右子树,那么既然是这样的话,就需要遍历到二叉树的每个结点。则你选择前序遍历、中序遍历、后序遍历、层序遍历。都可以。只要是可以遍历到二叉树的每个结点,然后交换它的左右子树
以下是中序遍历实现翻转的代码:

public TreeNode invertTree(TreeNode root){
        if (root == null) return null;
        invertTree(root.left);
        
        TreeNode tmp = root.left;
        root.left = root.right;
        root.right = tmp;
        
        invertTree(root.left);
        //注意上面中序遍历处理当前结点的时候左右子树发生了交换,所以这列写root.left其实是结点交换前的right
//        Queue<TreeNode> queue = new LinkedList<>();
//        queue.offer(root);
//        while(!queue.isEmpty()){
//            TreeNode node = queue.poll();
//            TreeNode temp = node.left;
//            node.left = node.right;
//            node.right = temp;
//            if (node.left != null) queue.offer(node.left);
//            if (node.right != null) queue.offer(node.right);
//        }
        return root;
    }

以下给出实现二叉树翻转的层序遍历的代码:

//翻转二叉树
    public TreeNode invertTree(TreeNode root){
        if (root == null) return null;
        Queue<TreeNode> queue = new LinkedList<>();
        queue.offer(root);
        while(!queue.isEmpty()){
            TreeNode node = queue.poll();
            TreeNode temp = node.left;
            node.left = node.right;
            node.right = temp;
            if (node.left != null) queue.offer(node.left);
            if (node.right != null) queue.offer(node.right);
        }
        return root;
    }

请读者自行实现前序,后序翻转二叉树代码。若需要帮助请在评论区留言!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值