当前位置: 首页 > news >正文

北京微信网站建设电话网站运营培训学校

北京微信网站建设电话,网站运营培训学校,做网站成都哪家公司最好,做装修公司网站费用题目要求 序列化是将一个数据结构或者对象转换为连续的比特位的操作,进而可以将转换后的数据存储在一个文件或者内存中,同时也可以通过网络传输到另一个计算机环境,采取相反方式重构得到原数据。 请设计一个算法来实现二叉树的序列化与反序…

题目要求

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

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

 

提示:

  • 树中结点数在范围 [0, 104] 内
  • -1000 <= Node.val <= 1000

解题思路

观察可知,二叉树的序列化和反序列化都是通过二叉树的层序遍历进行实现的,所以我们想要解题,就要通过二叉树的层序遍历的性质来进行解题。

遍历数组,当1个节点进入队列的时候,且弹出该节点之时,则当前处理的该节点算是一个根节点。按照层序遍历的特点,我们设有一个i指针。

当弹出节点的时候,i正好位于当前节点的左子结点。i自增1之后,则i处于当前根节点的右子节点中。若非空,则子节点加入栈。

代码解析

/*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode(int x) { val = x; }* }*/
public class Codec {// Encodes a tree to a single string.public String serialize(TreeNode root) {if (root == null){return "[]";}// 新建一个队列Queue<TreeNode> queue = new LinkedList<>();// 新建一个列表List<TreeNode> list = new ArrayList<>();// 根节点入队queue.offer(root);while (!queue.isEmpty()) {TreeNode node = queue.poll();if (node != null) {list.add(node);queue.offer(node.left);queue.offer(node.right);} else {list.add(null);}}StringBuilder sb = new StringBuilder();sb.append("[");sb.append(list.stream().map(node -> node == null ? "null" : String.valueOf(node.val)).collect(Collectors.joining(",")));sb.append("]");String result = sb.toString();return result;}// Decodes your encoded data to tree.public TreeNode deserialize(String data) {if (data.equals("[]")) {return null;}// 构造值数组String[] vals = data.substring(1, data.length() - 1).split(",");// 构造队列Queue<TreeNode> queue = new LinkedList<>();// 构造根节点TreeNode root = new TreeNode(Integer.parseInt(vals[0]));// 根节点加入队列queue.offer(root);int i = 1;while (!queue.isEmpty()) {// 弹出当前根节点TreeNode curRoot = queue.poll();if (!vals[i].equals("null")) {curRoot.left = new TreeNode(Integer.parseInt(vals[i]));queue.offer(curRoot.left);}i++;if (!vals[i].equals("null")) {curRoot.right = new TreeNode(Integer.parseInt(vals[i]));queue.offer(curRoot.right);}i++;}return root;}
}

http://www.jinmujx.cn/news/116123.html

相关文章:

  • 1g内存vps 开电影网站什么是软文
  • 境外网站在国内做镜像网站seo优化分析
  • 青岛市建设工程信息网官网河南靠谱seo电话
  • 门户网站做吗青岛网站推广公司
  • 影视公司网站设计成都网站优化seo
  • 用垃圾网站做外链查指数
  • 用明星名字做网站百度关键词搜索排名统计
  • 有哪些网站使用ftp郑州本地seo顾问
  • 网站名称可以更换吗百度一下电脑版
  • 建设银行天津分行网站谷歌google搜索引擎入口
  • 新乡哪里做网站真人seo点击平台
  • 订阅号怎么开通小程序长春seo外包
  • 广东中南建设有限公司网站广告优化师
  • 固原网站制作外包公司为什么没人去
  • 高端服装产品网站建设seo值怎么提高
  • 网站版权信息修改互联网推广广告
  • wordpress 响应seo优化排名易下拉效率
  • 安福网站建设做销售怎样去寻找客户
  • 网站建设有前途吗快速申请免费个人网站
  • 杭州高端网站制作唯尚广告联盟app下载
  • 云商城关键词排名优化公司成都
  • 做网站公司教育培训平台
  • 淘宝客网站WordPressseo高手培训
  • 如何用easyui做网站友链交换
  • 网站关键词在哪里做nba湖人最新新闻
  • web前端开发岗位职责专业的网站优化公司排名
  • 怎么在网站做推广和宣传高质量软文
  • 赣州做网站建设网站建设流程是什么
  • 余姚本地网站排名seo建站工具
  • 深圳前十网站扩广公司市场调研报告的基本框架