首页 > 其他 > 详细

leetcode第一刷_ Flatten Binary Tree to Linked List

时间:2017-04-14 19:40:50      阅读:270      评论:0      收藏:0      [点我收藏+]

提示中说明了,改动后的链表相当于原树的前序遍历结果。前序遍历是根左右,因为要把转换后的左子树链接到根节点的右子树上,因此进入递归之后要先把节点的右子树保存下来,然后进入左子树,左子树转换后应该返回最后一个訪问的节点。这个节点的后继是根节点的转换后右子树。说起来很绕,可能看代码反而好一些。

注意一个问题是,不管如何。转换后的根节点一定要把左子树置空。要么会报错的。

TreeNode* preOrder(TreeNode *root){
    if(!root||(!root->left&&!root->right))
        return root;
    TreeNode *pre=NULL, *next;
    next = root->right;
    if(root->left){
        root->right = root->left;
        pre = preOrder(root->left);
    }
    root->left = NULL;
    if(!next)
        return pre;
    if(pre)
        pre->right = next;
    return preOrder(next);
    
}
class Solution {
public:
    void flatten(TreeNode *root) {
        preOrder(root);
        return;
    }
};


leetcode第一刷_ Flatten Binary Tree to Linked List

原文:http://www.cnblogs.com/gccbuaa/p/6710337.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!