题目描述
请实现两个函数,分别用来序列化和反序列化二叉树
/*
struct TreeNode {
int val;
struct TreeNode *left;
struct TreeNode *right;
TreeNode(int x) :
val(x), left(NULL), right(NULL) {
}
};
*/
//思路:什么是序列化
/*********
序列化:使用单队列,将树{1,2,3}格式化为"1,2,3,#,#,#,#"
反序列化:使用双队列,一个用于存放字符串数据,一个用于存放TreeNode *指针
懂了、
//抄袭呀
*********/
class Solution {
public:
TreeNode* de(char *&str)
{
if(*str=='#')
{
str++;
return NULL;
}
int num=0;
while(*str!=',')
num=num*10+(*(str++)-'0');
str++;
TreeNode *root=new TreeNode(num);
root->left=de(str);
root->right=de(str);
return root;
}
char* Serialize(TreeNode *root) {
if(!root) return "#";
string s=to_string(root->val);
//转为字符串
s.push_back(',');
char *left=Serialize(root->left);
char *right=Serialize(root->right);
//啥意思
char *res=new char[strlen(left)+strlen(right)+s.size()];
strcpy(res,s.c_str());
strcat(res,left);
strcat(res,right);
return res;
}
TreeNode* Deserialize(char *str) {
return de(str);
}
};