题目描述
请实现两个函数,分别用来序列化和反序列化二叉树
思路
序列化:使用前序遍历,递归的将二叉树的值转化为字符。
反序列化:按照前序顺序,递归的使用字符串中的字符创建一个二叉树。
思路:使用全局变量vector存放前序遍历的结果,递归将前序遍历的结果放vector中,转化为字符即完成了序列化。为了反序列化比较方便,空节点存放一个特殊值(这里为oxFFFFFFFF)。递归将字符串中每一个字符变成树的一个节点,若为特殊值,设为NULL。
/*
struct TreeNode {
int val;
struct TreeNode *left;
struct TreeNode *right;
TreeNode(int x) :
val(x), left(NULL), right(NULL) {
}
};
*/
class Solution {
public:
vector<int>buf;
void frontputin(TreeNode *root)
{
if(root==NULL)
{
buf.push_back(0xFFFFFFFF);
return;
}
else
buf.push_back(root->val);
frontputin(root->left);
frontputin(root->right);
}
TreeNode *frontputout(int *&p)
{
if(*p==0xFFFFFFFF)
{
p++;
return NULL;
}
TreeNode *res=new TreeNode (*p);
p++;
res->left=frontputout(p);
res->right=frontputout(p);
return res;
}
char* Serialize(TreeNode *root) {
buf.clear();
frontputin(root);
int bufsize=buf.size();
int *res=new int[bufsize];
for(int i=0;i<bufsize;i++)
res[i]=buf[i];
return (char*)res;
}
TreeNode* Deserialize(char *str) {
int *p=(int *)str;
return frontputout(p);
}
};