首页 > 其他分享 >297. 二叉树的序列化与反序列化

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

时间:2022-11-06 22:59:33浏览次数:53  
标签:null return dataList 二叉树 str 297 序列化 root

序列化是将一个数据结构或者对象转换为连续的比特位的操作,进而可以将转换后的数据存储在一个文件或者内存中,同时也可以通过网络传输到另一个计算机环境,采取相反方式重构得到原数据。

请设计一个算法来实现二叉树的序列化与反序列化。这里不限定你的序列 / 反序列化算法执行逻辑,你只需要保证一个二叉树可以被序列化为一个字符串并且将这个字符串反序列化为原始的树结构。

示例 1:

 

 

输入:root = [1,2,3,null,null,4,5]
输出:[1,2,3,null,null,4,5]

示例 2:

输入:root = []
输出:[]

示例 3:

输入:root = [1]
输出:[1]

示例 4:

输入:root = [1,2]
输出:[1,2]

提示:

  • 树中结点数在范围 [0, 104] 内
  • -1000 <= Node.val <= 1000
 1 /**
 2  * Definition for a binary tree node.
 3  * function TreeNode(val) {
 4  *     this.val = val;
 5  *     this.left = this.right = null;
 6  * }
 7  */
 8 
 9 /**
10  * Encodes a tree to a single string.
11  *
12  * @param {TreeNode} root
13  * @return {string}
14  */
15 var serialize = function(root) {
16      return rserialize(root, '');
17 };
18 
19 /**
20  * Decodes your encoded data to tree.
21  *
22  * @param {string} data
23  * @return {TreeNode}
24  */
25 var deserialize = function(data) {
26     const dataArray = data.split(",");
27     return rdeserialize(dataArray);
28 };
29 
30 /**
31  * Your functions will be called as such:
32  * deserialize(serialize(root));
33  */
34  const rserialize = (root, str) => {
35     if (root === null) {
36         str += "None,";
37     } else {
38         str += root.val + '' + ",";
39         str = rserialize(root.left, str);
40         str = rserialize(root.right, str);
41     }
42     return str;
43 }
44 
45 const rdeserialize = (dataList) => {
46     if (dataList[0] === "None") {
47         dataList.shift();
48         return null;
49     }
50 
51     const root = new TreeNode(parseInt(dataList[0]));
52     dataList.shift();
53     root.left = rdeserialize(dataList);
54     root.right = rdeserialize(dataList);
55 
56     return root;
57 }

标签:null,return,dataList,二叉树,str,297,序列化,root
From: https://www.cnblogs.com/icyyyy/p/16864516.html

相关文章

  • java 使用序列化写出或者读取对象
    进行写出前,建议在pojo类中,定义属性“serialVersionUID“,否则对象以后要更改或添加属性时,再读取原来的文件会报错例如下面实体类publicclassRenimplementsSerializa......
  • 不知道为什么递归失败 二叉树 演我?
    不知道为什么不能够递归搞明白了再更啊哈哈哈怎么突然就行了准备截一张失败的图来着然后突然就出来了也不知道之前为什么失败  非递归的今天晚上应该写不出来了......
  • #yyds干货盘点# LeetCode 腾讯精选练习 50 题:二叉树中的最大路径和
    题目:路径被定义为一条从树中任意节点出发,沿父节点-子节点连接,达到任意节点的序列。同一个节点在一条路径序列中至多出现一次。该路径至少包含一个节点,且不一定经过根节......
  • 二叉树中查找后继节点问题
    二叉树中查找后继节点问题作者:Grey原文地址:博客园:二叉树中查找后继节点问题CSDN:二叉树中查找后继节点问题题目描述给定一个二叉查找树,以及一个节点,求该节点在中序遍......
  • [Java反序列化]JavaCC链学习(8u71前)
    文章目录​​写在前面​​​​前置​​​​Transformer​​​​TransformedMap​​​​ChainedTransformer​​​​InvokerTransformer​​​​ConstantTransformer​​​​......
  • Java中的序列化
    序列化今天想看看SpringBoot集中处理Exception的注解,继承RuntimeException的时候点进去看了一下源码,发现有一个成员属性  查了一下这个serialVersionUID的用处,简单......
  • java对象的反序列化和序列化
    对象的序列化packagecom.tedu.day1301;importjava.io.FileOutputStream;importjava.io.ObjectOutputStream;importjava.io.Serializable;/*完成序列化序列化:......
  • 236. 二叉树的最近公共祖先
    给定一个二叉树,找到该树中两个指定节点的最近公共祖先。百度百科中最近公共祖先的定义为:“对于有根树T的两个节点p、q,最近公共祖先表示为一个节点x,满足x是p、q......
  • 114. 二叉树展开为链表
    给你二叉树的根结点 root ,请你将它展开为一个单链表:展开后的单链表应该同样使用 TreeNode ,其中 right 子指针指向链表中下一个结点,而左子指针始终为 null 。展......
  • 二叉树的最大宽度系列问题
    二叉树的最大宽度系列问题作者:Grey原文地址:博客园:二叉树的最大宽度系列问题CSDN:二叉树的最大宽度系列问题求树的最大宽度题目描述给你一棵二叉树的根节点root,返......