acwing 50. 序列化二叉樹

地址 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

相關文章
相關標籤/搜索