zoukankan      html  css  js  c++  java
  • 剑指offer---序列化二叉树

    /*
    struct TreeNode {
        int val;
        struct TreeNode *left;
        struct TreeNode *right;
        TreeNode(int x) :
                val(x), left(NULL), right(NULL) {
        }
    };
    */
    
    
    class Solution {
    public:
        void serializeHelper(TreeNode *node, string& s)
        {
            if (node == NULL)
            {
                s.push_back('N');
                s.push_back(',');
                return;
            }
            s += to_string(node->val);
            s.push_back(',');
            serializeHelper(node->left, s);
            serializeHelper(node->right, s);
        }
        char* Serialize(TreeNode *root)
        {
            if (root == NULL)
                return NULL;
            string s = "";
            serializeHelper(root, s);
     
            char *ret = new char[s.length() + 1];
            strcpy(ret, s.c_str());
            return ret;
        }
         
        TreeNode *deserializeHelper(string &s)
        {
            if (s.empty()) 
                return NULL;
            if (s[0] == 'N')
            {
                s = s.substr(2);
                return NULL;
            }
            TreeNode *ret = new TreeNode(stoi(s));
            s = s.substr(s.find_first_of(',') + 1);
            ret->left = deserializeHelper(s);
            ret->right = deserializeHelper(s);
            return ret;
        }
         
        TreeNode* Deserialize(char *str) 
        {
            if (str == NULL)
                return NULL;
            string s(str);
            return deserializeHelper(s);
        }
    };

    我还是喜欢用vector做

  • 相关阅读:
    Linux 切换用户
    Java之.jdk安装-Linux
    Java之.jdk安装-Windows
    java注解生成xml和包含CDATA问题
    Spring学习—生成图片验证码
    java学习——java按值传递和按址传递
    温水中被煮熟的程序员-人生的思考
    mysql操作sql的小技巧
    java的classLoader分析与jettty的WebAppClassLoader
    深入Spring:自定义事务管理
  • 原文地址:https://www.cnblogs.com/159269lzm/p/7271454.html
Copyright © 2011-2022 走看看