zoukankan      html  css  js  c++  java
  • 序列化二叉树

    题目描述

    请实现两个函数,分别用来序列化和反序列化二叉树
     
    解题思路:
    利用层次遍历的思想。序列化时,节点值用“ ”空格隔开,空节点使用“#”代替。
    反序列化时把提取出来的节点放入队列中,每次循环都处理的是该节点的左右儿子节点。
    class Solution {
    public:
    
        char* Serialize(TreeNode *root) {
            string res;
            if(root == NULL) return NULL;
            queue<TreeNode*> que;
            TreeNode * tmpNode = NULL;
            que.push(root);
            res += tostring(root->val) + " ";
            while(!que.empty()){
                tmpNode = que.front();
                que.pop();
                if(tmpNode->left != NULL){
                    que.push(tmpNode->left);
                    res+= tostring(tmpNode->left->val) + " ";
                }else{
                    res += "# ";
                }
                if(tmpNode->right != NULL){
                    que.push(tmpNode->right);
                    res+= tostring(tmpNode->right->val) + " ";
                }else{
                    res += "# ";
                }
            }
            int len = res.size();
            char *ret = new char[len+1];
            strcpy(ret, res.c_str());
            return ret;
        }
        TreeNode* Deserialize(char *str) {
            int i = 0;
            if(str == NULL) return NULL;
            if(str[0] == '') return NULL;
            int num = pickNum(str, i);
            queue<TreeNode*> que;
            TreeNode *ret = new TreeNode(num);
            TreeNode* tmpNode = NULL;
            que.push(ret);
            while(!que.empty()){
                tmpNode = que.front();
                que.pop();
                cout<<"tmpNode->val="<<tmpNode->val<<endl;
                cout<<"str[i]="<<str[i]<<endl;
                if(str[i] >= '0' && str[i] <= '9'){
                    int lv = pickNum(str, i);
                    //cout<<"lv="<<lv<<endl;
                    tmpNode->left = new TreeNode(lv);
                    que.push(tmpNode->left);
                }else{
                    if(str[i] == '#'){
                        i+=2;
                    }
                }
                if(str[i] >= '0' && str[i] <= '9'){
                    int rv = pickNum(str, i);
                    //cout<<"rv="<<rv<<endl;
                    tmpNode->right = new TreeNode(rv);
                    que.push(tmpNode->right);
                }else{
                    if(str[i] == '#'){
                        i+=2;
                    }
                }
            }
            return ret;
        }
       //打印二叉树的层次结构
       vector<vector<int> > Print(TreeNode* pRoot) {
                vector<vector<int> > res;
                if(pRoot == NULL) return res;
                queue<TreeNode *> que1, que2;
                que1.push(pRoot);
                res.push_back(vector<int>(1, pRoot->val));
                TreeNode* tmpNode=NULL;
                while(!que1.empty() || !que2.empty()){
                    vector<int>tmpVct;
                    while(!que1.empty()){
                        tmpNode = que1.front();
                        que1.pop();
                        if(tmpNode->left != NULL){
                            que2.push(tmpNode->left);
                            tmpVct.push_back(tmpNode->left->val);
                        }
                        if(tmpNode->right != NULL){
                            que2.push(tmpNode->right);
                            tmpVct.push_back(tmpNode->right->val);
                        }
                    }
                    if(tmpVct.size() != 0)
                        res.push_back(tmpVct);
                    tmpVct.clear();
                    while(!que2.empty()){
                        tmpNode = que2.front();
                        que2.pop();
                        if(tmpNode->left != NULL){
                            que1.push(tmpNode->left);
                            tmpVct.push_back(tmpNode->left->val);
                        }
                        if(tmpNode->right != NULL){
                            que1.push(tmpNode->right);
                            tmpVct.push_back(tmpNode->right->val);
                        }
                    }
                    if(tmpVct.size() != 0)
                        res.push_back(tmpVct);
                }
                return res;
            }
    private:
        string tostring(int a){
            strstream ss;
            ss<<a;
            string res;
            ss>>res;
            return res;
        }
        int pickNum(char *str, int & i){
            int res = 0;
            while(str[i]>='0' && str[i] <= '9'){
                res = res*10 + str[i]-'0';
                i++;
            }
            if(str[i] == ' ') i++;
            return res;
        }
    };
    

      

  • 相关阅读:
    HDU 5251 矩形面积 (旋转卡壳)
    洛谷 P3187 BZOJ 1185 [HNOI2007]最小矩形覆盖 (旋转卡壳)
    2019 杭电多校 第十场
    2019 杭电多校 第八场
    2019 杭电多校 第九场
    2019 杭电多校 第七场
    2019 杭电多校 第六场
    2019 杭电多校 第五场
    2019 杭电多校 第四场
    2019 杭电多校 第三场
  • 原文地址:https://www.cnblogs.com/chengsheng/p/10702353.html
Copyright © 2011-2022 走看看