将二叉树拆成链表

描述

将一棵二叉树按照前序遍历拆解成为一个假链表。所谓的假链表是说,用二叉树的 right 指针,来表示链表中的 next 指针。

注意事项

不要忘记将左儿子标记为 null,否则你可能会得到空间溢出或是时间溢出。

样例

                1
                  \
     1             2
    / \               \
   2   5    =>         3
  / \   \                \
 3   4   6                 4
                             \
                               5
                                 \
                                  6

标签

二叉树&深度优先搜索

相关题目

Flattern 2D Vector & 摊平嵌套的链表 &将二叉树按照层级转换为链表 &
将二叉查找树转换为双链表&排序链表转换为二叉树

代码实现

/**
 * Definition of TreeNode:
 * public class TreeNode {
 *     public int val;
 *     public TreeNode left, right;
 *     public TreeNode(int val) {
 *         this.val = val;
 *         this.left = this.right = null;
 *     }
 * }
 */
public class Solution {
    /**
     * @param root: a TreeNode, the root of the binary tree
     * @return: nothing
     */
    public void flatten(TreeNode root) {
         helper(root);
    }
    // flatten root and return the last node
    private TreeNode helper(TreeNode root) {
        if (root == null) {
            return root;
        }
        TreeNode leftLast = helper(root.left);
        TreeNode rightLast = helper(root.right);

        // connect leftLast to root.right
        //root.right 接到leftLast的右子树
        //root.left置null
        if (leftLast != null) {
            leftLast.right = root.right;
            root.right = root.left;
            root.left = null;
        }
        //返回新链表的最后一个节点
        //因为是前序遍历,必然先判断右子树,再左子树,最后根节点
        if (rightLast != null) {
            return rightLast;
        }
        if (leftLast != null) {
            return leftLast;
        }
        return root;
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 描述 将一棵二叉树按照前序遍历拆解成为一个假链表。所谓的假链表是说,用二叉树的 right 指针来表示链表中的 n...
    6默默Welsh阅读 655评论 0 0
  • 题目 将一棵二叉树按照前序遍历拆解成为一个假链表。所谓的假链表是说,用二叉树的 right 指针,来表示链表中的 ...
    六尺帐篷阅读 595评论 0 1
  • 版权声明:本文为博主原创文章,未经博主允许不得转载。 难度:容易 要求: 将一棵二叉树按照前序遍历拆解成为一个假链...
    柒黍阅读 323评论 0 0
  • 树的概述 树是一种非常常用的数据结构,树与前面介绍的线性表,栈,队列等线性结构不同,树是一种非线性结构 1.树的定...
    Jack921阅读 4,509评论 1 31
  • 突然有点想写文章的冲动,总想写下一些东西,想法也好,经历也好,或者是自己当下的生活状况。就当作是一次重新认识自己吧...
    词穷因为没墨水阅读 184评论 0 0