【待整理】二叉树的序列化和反序列化

在这里插入图片描述
我们在内存里可以串起一棵树,
但是我们总得想办法保存下来。
比如机器要关了,内存里的东西都要销毁了,
我们需要怎么样才能将指针那些东西保存成文件的格式!以便于我们下回重建出这棵树。
这就是本节要讲的 序列化和反序列化的问题!

序列化:一些数据 ,用什么形式可以记录下来。记录的过程,就叫序列化。
反序列化:把一个文件中的内容怎么还原出内存中的数结构 ,即为反序列化。

哈希表怎么序列化反序列 化的?

巨简单!
序列化:把哈希表遍历,key和value每行对应记到另一个文件
反序列化:把这个文件中一行行key和value 重新还原。

先序方式序列化:
在这里插入图片描述
例如,这个数是存在于内存中的,那么怎样序列化将其变为字符串呢?
1.先序方式序列化
先序遍历会遍历哪个节点?
在这里插入图片描述
4节点之后是空节点
在序列化中,我们要把空也记到序列化中
可以用诸如 # 的特殊符号

遍历完是这个样子:
在这里插入图片描述
代码见code04
主程序:
在这里插入图片描述

运行结果为:
在这里插入图片描述
为何要加#号呢?
若是不加#号,则诸如这种情况是区分不开的!
在这里插入图片描述
为何要用!结尾
因为如果不用类似符号结尾的话,区分不开如下情况:
在这里插入图片描述
在这里插入图片描述

反序列化:

形成字符串后。如何还原成另一个字符串!
例子:只给出如下字符串,如何还原!
在这里插入图片描述
既然我们用先序遍历的方式来序列化
所以用先序遍历的方式来反序列化
在这里插入图片描述

按层序列化!

在这里插入图片描述

01.48.00

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值