首先我們介紹二叉樹先序序列化的方式,假設序列化的結(jié)果字符串為str,初始時str等于空字符串。先序遍歷二叉樹螺垢,如果遇到空節(jié)點,就在str的末尾加上“#!”,“#”表示這個節(jié)點為空甩苛,節(jié)點值不存在蹂楣,當然你也可以用其他的特殊字符,“!”表示一個值的結(jié)束讯蒲。如果遇到不為空的節(jié)點痊土,假設節(jié)點值為3,就在str的末尾加上“3!”∧郑現(xiàn)在請你實現(xiàn)樹的先序序列化赁酝。
給定樹的根結(jié)點root,請返回二叉樹序列化后的字符串旭等。
測試樣例:
/*
struct TreeNode {
int val;
struct TreeNode *left;
struct TreeNode *right;
TreeNode(int x) :
val(x), left(NULL), right(NULL) {
}
};*/
class TreeToString {
public:
void preoder(const TreeNode* root, string& res)
{
if(NULL == root) {
res += "#!";
return;
}
res += to_string(root->val) + "!";
preoder(root->left, res);
preoder(root->right, res);
}
string toString(TreeNode* root) {
// write code here
string res;
preoder(root, res);
return res;
}
};