[Interview] Serialize and De-serialize a tree

本文介绍了一种利用前序遍历实现树的序列化与反序列化的方法,并给出了具体的实现代码。同时探讨了为何只有前序遍历适合此操作的原因。
A very frequent interview question. Suppose you have a tree, how could you serialize it to file and revert it back?


for example,

                                               1
                                         /               \
                                        2                 3
                                             \          /    
                                             4        5    
                                          /       \
                                         6        7

[Thoughts]
一个比较简单直接的做法是,通过前序遍历来做,把所有空节点当做“#”来标示。那么这棵树可以表示为

                                               1
                                         /               \
                                        2                 3
                                     /       \          /      \
                                  #         4        5       #
                                          /       \
                                         6        7
                                     /      \     /    \
                                    #      #    #     #

那么前序遍历的结果就是: {'1','2','#','4','6','#','#','7','#','#','3','5','#','#','#'}; 代码如下:


void Serialize(TreeNode * node, vector<char> &output)

{

       if(node == NULL)

       {

             output.push_back('#');

             return;

       }


       output.push_back(node->val + '0');

       Serialize(node->left, output);

       Serialize(node->right, output);

}


而反序列化的代码也就是:

TreeNode *Deserialize(vector<char> output, int &index)

{

       if(index > output.size() || output[index] == '#') return NULL;


       TreeNode *node = new TreeNode(output[index] -'0');

       index ++;

       node->left = Deserialize(output, index);

       index++;

       node->right = Deserialize(output, index);

       return node;

}



这里只能通过前序遍历来做,中序及后序是行不通的。原因很简单,除了前序以外,其他遍历方式没办法找出头结点。

除了常规的三种遍历方式意外, 另一种可行的方法就是按层来遍历,同样可行。










转载于:https://www.cnblogs.com/codingtmd/archive/2013/03/23/5078882.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值