欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 文旅 > 游戏 > Leetcode—297. 二叉树的序列化与反序列化【困难】

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

2025/4/19 19:58:51 来源:https://blog.csdn.net/qq_44631615/article/details/140668316  浏览:    关键词:Leetcode—297. 二叉树的序列化与反序列化【困难】

2024每日刷题(148)

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

在这里插入图片描述

实现代码

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

运行结果

在这里插入图片描述

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

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词