Leetcode—297. 二叉树的序列化与反序列化【困难】

2024每日刷题(148)

Leetcode---297. 二叉树的序列化与反序列化

实现代码

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Codec {
public:

    // Encodes a tree to a single string.
    string serialize(TreeNode* root) {
        string ans;

        function<void(TreeNode*)> preorder = [&](TreeNode* root) {
            if(root == nullptr) {
                ans += "null ";
                return;
            }
            
            ans += to_string(root->val) + " ";
            preorder(root->left);
            preorder(root->right);
        };

        preorder(root);
        return ans;
    }

    // Decodes your encoded data to tree.
    TreeNode* deserialize(string data) {
        istringstream iss(data);

        queue<string> q;
        for(string s; iss >> s;) {
            q.push(s);
        }

        function<TreeNode*()> preorder = [&]() {
            string node = q.front();
            q.pop();
            if(node == "null") {
                return (TreeNode*)nullptr;
            }

            TreeNode* newNode = new TreeNode(stoi(node));
            newNode->left = preorder();
            newNode->right = preorder();
            return newNode;
        };

        return preorder();
    }
};

// Your Codec object will be instantiated and called as such:
// Codec ser, deser;
// TreeNode* ans = deser.deserialize(ser.serialize(root));

运行结果

之后我会持续更新,如果喜欢我的文章,请记得一键三连哦,点赞关注收藏,你的每一个赞每一份关注每一次收藏都将是我前进路上的无限动力 !!!↖(▔▽▔)↗感谢支持!

相关推荐
Blossom.1182 小时前
移动端部署噩梦终结者:动态稀疏视觉Transformer的量化实战
java·人工智能·python·深度学习·算法·机器学习·transformer
轻微的风格艾丝凡3 小时前
卷积的直观理解
人工智能·深度学习·神经网络·算法·计算机视觉·matlab·cnn
田梓燊5 小时前
红黑树分析 1
算法
晚风吹长发6 小时前
二分查找算法+题目详解
c++·算法·二分查找
悠悠~飘6 小时前
18.PHP基础-递归递推算法
算法·php
pilgrim536 小时前
结合 Leetcode 题探究KMP算法
算法·leetcode
罗义凯6 小时前
其中包含了三种排序算法的注释版本(冒泡排序、选择排序、插入排序),但当前只实现了数组的输入和输出功能。
数据结构·c++·算法
kevien_G17 小时前
JAVA之二叉树
数据结构·算法
春蕾夏荷_7282977257 小时前
c++ easylogging 使用示例
c++·log·easylogging
syt_biancheng7 小时前
Day3算法训练(简写单词,dd爱框框,3-除2!)
开发语言·c++·算法·贪心算法