序列化二叉树
来源:互联网 发布:两心之外无人知意思 编辑:程序博客网 时间:2024/05/21 05:17
题目描述
请实现两个函数,分别用来序列化和反序列化二叉树
/*
struct TreeNode {
int val;
struct TreeNode *left;
struct TreeNode *right;
TreeNode(int x) :
val(x), left(NULL), right(NULL) {
}
};
*/
//思路:什么是序列化
/*********
序列化:使用单队列,将树{1,2,3}格式化为"1,2,3,#,#,#,#"
反序列化:使用双队列,一个用于存放字符串数据,一个用于存放TreeNode *指针
懂了、
//抄袭呀
*********/
class Solution {
public:
TreeNode* de(char *&str)
{
if(*str=='#')
{
str++;
return NULL;
}
int num=0;
while(*str!=',')
num=num*10+(*(str++)-'0');
str++;
TreeNode *root=new TreeNode(num);
root->left=de(str);
root->right=de(str);
return root;
}
char* Serialize(TreeNode *root) {
if(!root) return "#";
string s=to_string(root->val);
//转为字符串
s.push_back(',');
char *left=Serialize(root->left);
char *right=Serialize(root->right);
//啥意思
char *res=new char[strlen(left)+strlen(right)+s.size()];
strcpy(res,s.c_str());
strcat(res,left);
strcat(res,right);
return res;
}
TreeNode* Deserialize(char *str) {
return de(str);
}
};
- 二叉树序列化
- 二叉树序列化
- 序列化二叉树
- 序列化二叉树
- 序列化二叉树
- 序列化二叉树
- 序列化二叉树
- 序列化二叉树
- 序列化二叉树
- 序列化二叉树
- 序列化二叉树
- 序列化二叉树
- 序列化二叉树
- 二叉树序列化
- 序列化二叉树
- 序列化二叉树
- 序列化二叉树
- 序列化二叉树
- java 多线程研究:锁的概念
- glibc源码分析之普通文件读写
- mangodb本地安装和使用
- OCLint的部分规则(Basic 部分)
- 贪心法和动态规划法的区别
- 序列化二叉树
- Orleans简介
- spring 配置文件遇见了父子上下文
- 数据库学习纪要(五):hive-5
- CodeForces
- 【算法】 简单选择排序与直接插入排序
- 网络请求
- Node.js, Require 和 Exports
- poj 2553 强连通求出度为零的点集合