LeetCode算法题-Invert Binary Tree

本人花费半年的时间总结的《Java面试指南》已拿腾讯等大厂offer,已开源在github ,欢迎star!

本文GitHub https://github.com/OUYANGSIHAI/JavaInterview 已收录,这是我花了6个月总结的一线大厂Java面试总结,本人已拿大厂offer,欢迎star

原文链接:blog.ouyangsihai.cn >> LeetCode算法题-Invert Binary Tree

这是悦乐书的第194次更新,第199篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第55题(顺位题号是226)。反转二叉树。例如:

输入:


    4
   / 
  2   7
 /  / 
1  3 6  9

输出:


    4
   / 
  7   2
 /  / 
9  6 3  1

本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。

02 第一种解法

二叉树的任意一个节点进行反转操作时,当前节点还是当前节点,当前节点的左子节点变成右子节点,当前节点的右子节点变成左子节点。也就是下面的三行核心代码:


TreeNode temp = root.left;
root.left = root.right;
root.right = temp;

如果从根节点开始,那么先把根节点的左右子节点互换,然后利用递归,再将已经互换了的左右子节点他们自身的左右子节点进行互换,最后返回root。


public TreeNode invertTree(TreeNode root) {
    if (root == null || (root.left == null && root.right == null)) {
        return root;
    }
    TreeNode temp = root.left;
    root.left = root.right;
    root.right = temp;
    root.left = invertTree(root.left);
    root.right = invertTree(root.right);
    return root;
}

03 第二种解法

此解法比上面的第一种解法精简了些,直接将上面核心代码进行套用,将root的左子节点取出存入tmp,再将root的左子节点指向递归后的root的右子节点,再将root的右子节点指向递归后的tmp,最后返回root即可。


public TreeNode invertTree2(TreeNode root) {
    if (root == null || (root.left == null && root.right == null)) {
        return root;
    }
    TreeNode tmp = root.left;
    root.left = invertTree2(root.right);
    root.right = invertTree2(tmp);
    return root;
}

04 第三种解法

利用队列,借助其先进先出的特性。在进行循环进队列、出队列的操作时,核心代码还是最开始那三行代码,进行左右子节点互换。


public TreeNode invertTree3(TreeNode root) {
    TreeNode r = root;
    QueueTreeNode q = new LinkedListTreeNode();
    if (root != null) {
        q.add(root);        
    }
    while (!q.isEmpty()) {
        TreeNode curr = q.remove();
        TreeNode temp = curr.left;
        curr.left = curr.right;
        curr.right = temp;
        if (curr.left != null) {
            q.add(curr.left);
        }
        if (curr.right != null) {
            q.add(curr.right);
        }
    }
    return r;
}

05 小结

算法专题目前已连续日更超过一个月,算法题文章55+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

LeetCode算法题-Invert Binary Tree

可能你还想看:

LeetCode算法题-Invert Binary Tree

原文始发于微信公众号( 悦乐书 ):

本人花费半年的时间总结的《Java面试指南》已拿腾讯等大厂offer,已开源在github ,欢迎star!

本文GitHub https://github.com/OUYANGSIHAI/JavaInterview 已收录,这是我花了6个月总结的一线大厂Java面试总结,本人已拿大厂offer,欢迎star

原文链接:blog.ouyangsihai.cn >> LeetCode算法题-Invert Binary Tree


 上一篇
LeetCode算法题-Power Of Two LeetCode算法题-Power Of Two
这是悦乐书的第194次更新,第200篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第56题(顺位题号是231)。给定一个整数,写一个函数来确定它是否是2的幂。例如: 输入:1 输出:true 说明:2
2021-04-05
下一篇 
LeetCode算法题-Implement Queue Using Stacks LeetCode算法题-Implement Queue Using Stacks
这是悦乐书的第195次更新,第201篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第57题(顺位题号是232)。使用栈实现队列的以下操作。 push(x) - 将元素x推送到队列的后面。 pop()
2021-04-05