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));

运行结果

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

相关推荐
Ven%7 分钟前
【AI大模型算法工程师面试题解析与技术思考】
人工智能·python·算法
天勤量化大唯粉8 分钟前
枢轴点反转策略在铜期货中的量化应用指南(附天勤量化代码)
ide·python·算法·机器学习·github·开源软件·程序员创富
我喜欢就喜欢15 分钟前
2025技术成长复盘:解决问题的365天
c++·qt
神仙别闹18 分钟前
基于QT(C++)+MySQL实现(窗体)学生信息管理系统
c++·qt·mysql
爱学习的小仙女!23 分钟前
算法效率的度量 时间复杂度 空间复杂度
数据结构·算法
AndrewHZ26 分钟前
【复杂网络分析】什么是图神经网络?
人工智能·深度学习·神经网络·算法·图神经网络·复杂网络
Swizard33 分钟前
拒绝“狗熊掰棒子”!用 EWC (Elastic Weight Consolidation) 彻底终结 AI 的灾难性遗忘
python·算法·ai·训练
U-52184F691 小时前
C++ 实战:构建通用的层次化数据模型 (Hierarchical Data Model)
开发语言·c++
charlie1145141911 小时前
深入解构:MSVC 调试机制与 Visual Studio 调试器原理
c++·ide·windows·学习·visual studio·调试·现代c++
Trouvaille ~1 小时前
【C++篇】把混沌映射成秩序:哈希表的底层哲学与实现之道
数据结构·c++·stl·哈希算法·散列表·面向对象·基础入门