描述
序列化是将一个数据结构或者对象转换为连续的比特位的操作,进而可以将转换后的数据存储在一个文件或者内存中,同时也可以通过网络传输到另一个计算机环境,采取相反方式重构得到原数据。
请设计一个算法来实现二叉树的序列化与反序列化。这里不限定你的序列 / 反序列化算法执行逻辑,你只需要保证一个二叉树可以被序列化为一个字符串并且将这个字符串反序列化为原始的树结构。
提示: 输入输出格式与 LeetCode 目前使用的方式一致,详情请参阅 LeetCode 序列化二叉树的格式。你并非必须采取这种方式,你也可以采用其他的方法解决这个问题。
示例 1:
输入:root = [1,2,3,null,null,4,5]
输出:[1,2,3,null,null,4,5]
实现
先序遍历实现
struct TreeNode{
int val;
TreeNode* left;
TreeNode* right;
TreeNode(int value): val(value), left(nullptr), right(nullptr){};
};
// 序列化
void rserialize(TreeNode* root, string& s){
if(root==nullptr){
s += "None,";
}else{
s += to_string(root->val) + ",";
rserialize(root->left, s);
rserialize(root->right, s);
}
}
string serialize(TreeNode* root){
string ret;
rserialize(root, ret);
return ret;
}
// 逆序列化
TreeNode* rdeserialize(list<string>& dataArray){
if(dataArray.front()=="None"){
dataArray.erase(dataArray.begin());
return nullptr;
}
TreeNode* root = new TreeNode(stoi(dataArray.front()));
dataArray.erase(dataArray.begin());
root->left = rdeserialize(dataArray);
root->right = rdeserialize(dataArray);
return root;
}
TreeNode* deserialize(string& ss){
list<string> dataArray;
string temp;
for(auto& c : ss){
if(c==","){
dataArray.push_back(temp);
temp.clear();
}else{
temp.push_back(c);
}
}
return rdeserialize(dataArray);
}
网友评论