LeetCode HOT 100 —— 297.二叉树的序列化与反序列化

news2024/10/2 8:33:05

题目

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

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

提示: 输入输出格式与 LeetCode 目前使用的方式一致,详情请参阅 LeetCode
序列化二叉树的格式。你并非必须采取这种方式,你也可以采用其他的方法解决这个问题。

在这里插入图片描述
在这里插入图片描述

思路

方法一:DFS | 深度优先搜索

(1)序列化:

  1. 采用递归的思想,遍历选择前序遍历,是因为 根∣左∣右 的打印顺序,在反序列化时更容易定位出根节点的值。
  2. 遇到 null 节点也要翻译成特定符号,反序列化时才知道这里是 null,这里用"X"表示null

(2)反序列化:

  1. 定义函数 buildTree 用于还原二叉树,传入由序列化字符串转成的 list 数组
  2. 逐个 poplist 的首项,构建当前子树的根节点,顺着 list,构建顺序是根节点→左子树→右子树
  3. 如果弹出的字符为 “X”,则返回 null 节点。
  4. 如果弹出的字符是数值,则创建root节点,并递归构建root的左右子树,最后返回root。

java代码如下:

class Codec{
	//序列化
	public String serialize(TreeNode root){
		if(root == null){
			return "X,";
		}
		String left = serialize(root.left);
		String right = serialize(root.right);
		return root.val + "," + left + right;
	}
	//反序列化
	public TreeNode deserialize(String data){
		String[] nodes = data.split(",");
		Queue<String> queue = new ArrayDeque<>(Arrays.asList(nodes));//队列用来存放列表形式的节点
		return buildTree(queue);
	}
	
	public TreeNode buildTree(Queue<String> queue){
		String value = queue.poll();
		if(value.equals("X")){
			return null;
		}
		TreeNode node = new TreeNode(Integer.parseInt(value));//将字符串转化成数字
		node.left = buildTree(queue);
		node.right = buildTree(queue);
		return node;
	}
}

方法二:BFS | 广度优先搜索

(1)序列化:

维护一个队列,初始让根节点入列,考察出列节点:

  1. 如果出列的节点是 null,将符号 "X" 推入 res 数组。
  2. 如果出列的节点是数值,将节点值推入数组 res,并将它的左右子节点入列。
  3. 子节点 null 也要入列,它对应 "X",要被记录,只是它没有子节点可入列。
  4. 入列、出列…直到队列为空,就遍历完所有节点,res构建完毕,转成字符串就好。

(2)反序列化:

依然先转成list数组,用一个指针 cur 从第二项开始扫描。

  1. 起初,用list[0]构建根节点,并让根节点入列。
  2. 节点出列,此时 cur 指向它的左子节点值,cur+1 指向它的右子节点值。
  3. 如果子节点值是数值,则创建节点,并认 出列 的父亲,同时自己也是父亲,入列。
  4. 如果子节点值为 "X",什么都不用做,因为出列的父亲的 leftright 本来就是 null
    可见,所有的真实节点都会在队列里走一遍,出列就带出儿子入列

java代码如下:

public class Codec {

    // 序列化
    public String serialize(TreeNode root) {
        if (root == null) {
            return "";
        }
        StringBuilder sb = new StringBuilder();
        Queue<TreeNode> queue = new LinkedList<>();
        queue.offer(root);
        while (!queue.isEmpty()) {
            TreeNode node = queue.poll();
            if (node == null) {
                sb.append("X,");
            } else {
                sb.append(node.val + ",");
                queue.offer(node.left);
                queue.offer(node.right);
            }
        }
        return sb.toString();
    }

    // 反序列化
    public TreeNode deserialize(String data) {
        if (data == "") {
            return null;
        }
        Queue<String> nodes = new ArrayDeque<>(Arrays.asList(data.split(",")));
        TreeNode root = new TreeNode(Integer.parseInt(nodes.poll()));
        Queue<TreeNode> queue = new ArrayDeque<>();
        queue.offer(root);
        while (!queue.isEmpty()) {
            TreeNode node = queue.poll();
            String left = nodes.poll();
            String right = nodes.poll();
            if (!left.equals("X")) {
                node.left = new TreeNode(Integer.parseInt(left));
                queue.add(node.left);
            }
            if (!right.equals("X")) {
                node.right = new TreeNode(Integer.parseInt(right));
                queue.add(node.right);
            }
        }
        return root;
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/95455.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

你还以为格子衫头发的就是程序员?这些特征都没有别说你是程序员

周一写几百个bug&#xff0c;周二到周四拼命改bug&#xff0c;周五总结bug&#xff0c;总结的好有周末&#xff0c;总结的不好周末无休&#xff01; 咳咳&#xff0c;这样的周末我可以不休息&#xff01; 有很多想要学习Python却找不到途径的朋友&#xff0c;我这里整理了一…

.NET Framework杂记

这篇博客主要记录在用C#编写上位机时&#xff0c;不会的知识点&#xff0c;随时更新&#xff0c;方便查阅。 C#语法操作杂记c#中让textbox选中不选中C#无法使用实例引用来访问成员解决方法针对不同定义情况的引用解释C# 字符串分割用字符串分割用多个字符串分割用单字符分割C#中…

【DevOps实战系列】第二章:详解Gitlab环境及搭建

个人亲自录制全套DevOps系列实战教程 &#xff1a;手把手教你玩转DevOps全栈技术 gitlab就不多说了&#xff0c;这个东西现在大多数公司内部都在使用&#xff0c;它分为社区和企业版本&#xff0c;社区版本ce是免费的&#xff0c;当然也可以选择gitee或github&#xff0c;但由于…

非零基础自学Golang 第8章 包管理 8.6 包的命名 8.7 依赖包管理

非零基础自学Golang 文章目录非零基础自学Golang第8章 包管理8.6 包的命名8.7 依赖包管理第8章 包管理 8.6 包的命名 每个包都有一个包名&#xff0c;包名一般是短小的名字&#xff0c;在包的声明处指定。 通常来说&#xff0c;默认的包名就是包导入路径名的最后一段&#x…

AD20和立创EDA设计(5)立创EDA导出3D模型放入AD20使用

&#xff08;1&#xff09;本文主要介绍如何将从立创EDA导出的3D模型&#xff0c;并且对3D模型进行处理。 &#xff08;2&#xff09;需提前观看&#xff1a;AD20和立创EDA设计&#xff08;4&#xff09;PCB设计&#xff1b; &#xff08;3&#xff09;本文需要使用到Fusion 36…

基于6自由度飞行器的EKF和INS融合算法的MATLAB仿真

目录 1.算法描述 2.仿真效果预览 3.MATLAB核心程序 4.完整MATLAB 1.算法描述 六自由度四轴飞行器,包括由四根杆组成的正四面体,所述正四面体的中心位置设有一个空心圆球,空心圆球上设有四根支杆分别与正四面体的四个顶点相连,所述空心圆球内设有电池和控制系统, INS/GPS的松…

nodejs+vue041家政管理系统

基本要求&#xff1a;要求此系统能较完善的实现服务人员及客户信息的管理等功能。 主界面&#xff1a;分为用户登陆和管理员登陆&#xff0c;用户登陆包含客户登录和服务人员登陆。 用户注册&#xff1a;注册时可选择身份&#xff08;客户或者服务人员&#xff09;。 后台管…

目前免费用可用的天气api接口及失效接口

网上关于免费天气api接口很多&#xff0c;本人总结了一下目前还可用的免费api接口和已失效的接口如下&#xff1a; 目前可用接口&#xff1a; 1、讯飞语音识别内置的墨迹天气API。链接&#xff1a; http://autodev.openspeech.cn/csp/api/v2.1/weather?openIdaiuicus&c…

【Javaweb-前端】CSS

1. Syntax Selector − A selector is an HTML tag at which a style will be applied. This could be any tag like or etc.Property − A property is a type of attribute of HTML tag. Put simply, all the HTML attributes are converted into CSS properties. They coul…

散热材料产业SWOT分析:5G建设带动市场需求 多元化散热方案将成行业主流

传统散热材料以石墨片和导热凝胶等TIM材料&#xff08;导热界面材料&#xff09;为主&#xff0c;石墨片存在导热系数相对较低、厚度相对较大等问题。目前热管和VC&#xff08;均热板&#xff09;开始从电脑、服务器等领域渗透到智能手机终端&#xff0c;石墨烯材料也开始应用。…

Docker笔记--容器转换为镜像、Dockerfile的使用

目录 1--使用 docker commit 将容器转换为镜像 1-1--容器转换为镜像 1-2--实例代码 1-3--注意事项&#xff1a; 2--Dockerfile的使用 2-1--常用关键字 2-2--利用 dockerfile 搭建 Centos:7 镜像 1--使用 docker commit 将容器转换为镜像 1-1--容器转换为镜像 # 将容器…

家电产品出口指南,RoHs法规详解

【家电产品出口指南&#xff0c;RoHs法规详解】 受疫情影响&#xff0c;我国家电出口创新高&#xff0c;据海关总署发布的数据统计&#xff0c;2021年&#xff0c;中国家用电器出口额987.2亿美元&#xff0c;同比增长22.3%&#xff0c;出口规模远超历史同期水平&#xff0c;创近…

新款Macbook Pro可以升级固态硬盘吗?

不知道有多少用户因为预算不足而选购了256GB固态硬盘版本的Mac呢&#xff1f;在购买Mac之前&#xff0c;总觉得“省省总会有的”。实际上&#xff0c;还是很多256G的用户都在后悔&#xff1a;“为什么当初没有加钱升级固态硬盘啊&#xff01;”小编在此也提醒大家&#xff0c;如…

让人恶心的多线程代码,性能怎么优化!

Java 中最烦人的&#xff0c;就是多线程&#xff0c;一不小心&#xff0c;代码写的比单线程还慢&#xff0c;这就让人非常尴尬。 通常情况下&#xff0c;我们会使用 ThreadLocal 实现线程封闭&#xff0c;比如避免 SimpleDateFormat 在并发环境下所引起的一些不一致情况。其实…

Java+MySQL校园网络超市系统的设计与实现 开题 论文

随着我国教育模式的改革,我国的大学生数量在逐步的增加,虽然每个高校的附近都有便利店但是很是时候这些便利店不能够满足学生的日常生活和学习的需求,尤其是便利店因为成本的原因货物不全 ,而大学生很多时候更希望通过网络购买自己所需的物品,所以通过校园网络超市系统来购买自…

基于java+springmvc+mybatis+vue+mysql的大学校医院信息管理系统

项目介绍 本系统采用java语言开发&#xff0c;后端采用ssm框架&#xff0c;前端采用vue技术&#xff0c;数据库采用mysql进行数据存储。 前台&#xff1a; 首页、校医、药品信息、疫情公告、个人中心、后台管理 后台&#xff1a; 首页、个人中心、在线问诊管理、问诊回复管理…

计算机毕设Python+Vue校园新闻广播系统(程序+LW+部署)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

[附源码]Node.js计算机毕业设计个人人际关系管理软件Express

项目运行 环境配置&#xff1a; Node.js最新版 Vscode Mysql5.7 HBuilderXNavicat11Vue。 项目技术&#xff1a; Express框架 Node.js Vue 等等组成&#xff0c;B/S模式 Vscode管理前后端分离等等。 环境需要 1.运行环境&#xff1a;最好是Nodejs最新版&#xff0c;我…

Mysql 数据库时间与系统时间不一致问题排查

NO.1 产生问题 在我们学习中使用到sysdate这个函数时&#xff0c;发现查出来的日期时间与当前的正确时间不一致&#xff0c;相差8个小时左右&#xff0c;为什么会产生这个问题&#xff1f;又该如何解决&#xff1f; – 在数据库中使用sysdate()函数查询系统时间 select sysd…

【MAX7800与ESP8266mcu串口通讯点灯】

【MAX7800与ESP8266mcu通讯】1. 前言2. 实验条件2.1 硬件条件2.2 软件条件3. 程序编写3.1 ESP8266程序解剖3.2 MAX7800程序解剖4. 实验效果4.1 esp8266打印如下4.2 max7800打印如下5. 小结1. 前言 前期搭好MAX7800 的eclipse和ESP82666的Arduino开发环境&#xff0c;现在开始慢…