[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;
}


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

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

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值