[题解]剑指 Offer 37. 序列化二叉树(C++)
2021/9/7 22:06:05
本文主要是介绍[题解]剑指 Offer 37. 序列化二叉树(C++),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
题目
请实现两个函数,分别用来序列化和反序列化二叉树。
你需要设计一个算法来实现二叉树的序列化与反序列化。这里不限定你的序列 / 反序列化算法执行逻辑,你只需要保证一个二叉树可以被序列化为一个字符串并且将这个字符串反序列化为原始的树结构。
提示:输入输出格式与 LeetCode 目前使用的方式一致,详情请参阅 LeetCode 序列化二叉树的格式。你并非必须采取这种方式,你也可以采用其他的方法解决这个问题。
示例:
输入:root = [1,2,3,null,null,4,5] 输出:[1,2,3,null,null,4,5]
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/xu-lie-hua-er-cha-shu-lcof
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
思路
用dfs,先序遍历二叉树,叶子节点的子节点记为空null,用逗号分隔节点。在反序列化的时候先根据逗号把原序列分割成节点元素,然后遍历元素列表,如果遇到null就记为空树,不是就先反序列化左子树,后反序列化右子树。
时间复杂度O(n),空间复杂度O(n)。
代码
/** * 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: void rserialize(TreeNode* root, string& ans){ if(root == nullptr){ ans += "null,"; } else{ ans += to_string(root->val) + ","; rserialize(root->left, ans); rserialize(root->right, ans); } } // Encodes a tree to a single string. string serialize(TreeNode* root) { string ans; rserialize(root, ans); return ans; } TreeNode* rdeserialize(list<string>& dataArray){ if(dataArray.front() == "null"){ dataArray.erase(dataArray.begin()); return nullptr; } TreeNode* root = new TreeNode(stoi(dataArray.front())); dataArray.erase(dataArray.begin()); root->left = rdeserialize(dataArray); root->right = rdeserialize(dataArray); return root; } // Decodes your encoded data to tree. TreeNode* deserialize(string data) { list<string> dataArray; string s; for(const auto& ch : data){ if(ch == ','){ dataArray.push_back(s); s.clear(); } else{ s.push_back(ch); } } if(!s.empty()){ dataArray.push_back(s); s.clear(); } return rdeserialize(dataArray); } }; // Your Codec object will be instantiated and called as such: // Codec codec; // codec.deserialize(codec.serialize(root));
这篇关于[题解]剑指 Offer 37. 序列化二叉树(C++)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-10Rakuten 乐天积分系统从 Cassandra 到 TiDB 的选型与实战
- 2025-01-09CMS内容管理系统是什么?如何选择适合你的平台?
- 2025-01-08CCPM如何缩短项目周期并降低风险?
- 2025-01-08Omnivore 替代品 Readeck 安装与使用教程
- 2025-01-07Cursor 收费太贵?3分钟教你接入超低价 DeepSeek-V3,代码质量逼近 Claude 3.5
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南
- 2025-01-03图像文字理解,OCR、大模型还是多模态模型?PalliGema2在QLoRA技术上的微调与应用