Flatten Binary Tree to Linked List

原创 2015年07月08日 20:08:30

Given a binary tree, flatten it to a linked list in-place.

For example,
Given

         1
        / \
       2   5
      / \   \
     3   4   6

The flattened tree should look like:
   1
    \
     2
      \
       3
        \
         4
          \
           5
            \
             6

解题思路:

将一颗二叉树转变成一个链表,如上图,看起来是一个链表,其实也还是一棵树,只不过左子树全部都是空的。

方法一:

由上面例子可知,新的树的链表读取顺序为原树的前序遍历。则我们设定一个额外的最初的节点。然后依次加入前序遍历的各节点即可。代码如下:

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    TreeNode* prenode=NULL;
    void preorder(TreeNode* root)
    {
        if(root)
        {
            TreeNode* leftnode=root->left;
            TreeNode* rightnode=root->right;
            if(prenode==NULL)//当这棵新树为空时,我们就将这棵树的根节点定位原树节点
            prenode=root;
            else
            {
                prenode->right=root;
                prenode->left=NULL;
                prenode=root;
            }
            preorder(leftnode);
            preorder(rightnode);
            
        }
    }
    void flatten(TreeNode* root) {
        if(root==NULL) return;
        preorder(root);
    }
};
注意:

我们采用的是递归的方法来实现前序遍历,为什么不用迭代呢?我尝试过,不过迭代的时候我们用一个栈存储一棵树的所有节点,需要根据之前入栈节点的左右节点来确定后来的节点,在此题中我们是要改变节点的左右节点的,所以这种方法再不重新开辟空间(生成新节点)的情况下是很难实现的。

方法二

由上面例子可知,我们将根节点的由节点先存储right,之后找到左子树的最右边的节点,将righta加到此节点的右边。左节点置空。这就处理完了根节点,之后再处理根节点的右节点,依次便可完成新节点的生成。
eg
     



代码如下:

class Solution {
public:
    void flatten(TreeNode* root) {
        if(root==NULL) return;
        if(root->right==NULL&&root->left==NULL) return;
        while(root)
        {
            if(root->left)
            {
                 TreeNode* le=root->left;
                 while(le->right)
                    le=le->right;
                 le->right=root->right;
                 root->right=root->left;
                 root->left=NULL;
            }
            root=root->right;
           
        }
    }
};


相关文章推荐

Leetcode Flatten Binary Tree to Linked List

深入理解了指针和树的操作,那么这道题是十分简单的,但是没理解好,那么这道题是非常难的。 重要一点:遍历访问的时候,不能改变没有访问过的树节点的结构。 也因为这一点,所以这道题不能像普通先序遍历那样写程...

LeetCode Flatten Binary Tree to Linked List

题目 Given a binary tree, flatten it to a linked list in-place. For example, Given 1 ...

114. Flatten Binary Tree to Linked List

Flatten Binary Tree to Linked List 如果能够使得叶子节点的right指向其后继的话,这样就很容易展成题目要求的形式了...
  • zzIymt
  • zzIymt
  • 2016年02月19日 09:51
  • 328

[Leetcode]Flatten Binary Tree to Linked List (三种方法)

Given a binary tree, flatten it to a linked list in-place. For example, Given 1 ...

[leetcode]114. Flatten Binary Tree to Linked List@Java解题报告

https://leetcode.com/problems/flatten-binary-tree-to-linked-list/description/ Given a bin...

[LeetCode] Flatten Binary Tree to Linked List 将二叉树展开成链表 C++

Given a binary tree, flatten it to a linked list in-place. For example, Given 1 ...

Leetcode 114. Flatten Binary Tree to Linked List

Given a binary tree, flatten it to a linked list in-place.For example, Given 1 / \ 2 5...

Leetcode: Flatten Binary Tree to Linked List

Given a binary tree, flatten it to a linked list in-place. For example, Given 1 ...

leetcode || 114、Flatten Binary Tree to Linked List

problem: Given a binary tree, flatten it to a linked list in-place. For example, Give...

Flatten Binary Tree to Linked List -- leetcode

Given a binary tree, flatten it to a linked list in-place. For example, Given 1 ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Flatten Binary Tree to Linked List
举报原因:
原因补充:

(最多只允许输入30个字)