地址 https://www.acwing.com/problem/content/46/node
請實現兩個函數,分別用來序列化和反序列化二叉樹。函數
您須要確保二叉樹能夠序列化爲字符串,而且能夠將此字符串反序列化爲原始樹結構。優化
你能夠序列化以下的二叉樹 8 / \ 12 2 / \ 6 4 爲:"[8, 12, 2, null, null, 6, 4, null, null, null, null]"
代碼spa
/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left(NULL), right(NULL) {} * }; */ class Solution { public: string str; // Encodes a tree to a single string. string serialize(TreeNode* root) { if (root == NULL) { if (!str.empty()) { str += ','; } str += "NULL"; return str; } if (!str.empty()) { str += ','; } str += to_string(root->val); serialize(root->left); serialize(root->right); //cout << "str = " << str<<endl; return str; } string ParseString( string& data, int& val) { string ret; if (data[0] == ',') { data = data.substr(1); } if (data.empty()) { // assert(0); val = -99999; return ""; } else if (data[0] == 'N') { val = -99999; ret = data.substr(4); } else if (data[0] >= '0' || data[0] <= '9') { int idx = 0; while (data[idx] != ',' && idx < data.size()) { idx++; } string numstr = data.substr(0, idx ); ret = data.substr(idx ); val = atoi(numstr.c_str()); } else { //assert(0); } if (ret[0] == ',') { ret = ret.substr(1); } return ret; } //8,12,NULL,NULL,2,6,NULL,NULL,4,NULL,NULL TreeNode* deserializeInner(string& data) { if (data.empty() || data == "NULL") return NULL; if (data[0] == ',') { data = data.substr(1); } int val = -99999; string nextStr = ParseString(data, val); data = nextStr; if (val == -99999) { return NULL; } TreeNode* root = (TreeNode*)malloc(sizeof(TreeNode)); memset(root, 0, sizeof(TreeNode)); root->val = val; root->left = deserializeInner(data); root->right = deserializeInner(data); return root; } // Decodes your encoded data to tree. TreeNode* deserialize(string data) { if (data.empty() ||data == "NULL") return NULL; //cout << data<<endl; int val = -1; string nextStr = ParseString(data, val); TreeNode* root = (TreeNode*)malloc(sizeof(TreeNode)); memset(root, 0, sizeof(TreeNode)); root->val = val; root->left = deserializeInner(nextStr); root->right = deserializeInner(nextStr); return root; } };
有點亂 待優化code