当前位置: 首页 > 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.wangmingla.cn/news/67196.html

相关文章:

  • 企业电子商务网站优化方案网络事件营销
  • 缪斯国际设计武汉seo关键字推广
  • 芜湖网站建设公司西安网站建设维护
  • 云羽网络做网站怎么样万网官网入口
  • 汇赢网站建设seo视频教学网站
  • 做企业网站一般多少钱个人网站该怎么打广告
  • 最新新闻热点事件2023年4月seo排名优化表格工具
  • 网站介绍模版长沙关键词排名首页
  • 口碑好的五屏网站建设阿里巴巴国际站
  • 营销型网站建设供货商淘宝流量平台
  • 申请好域名后 怎么做网站广告留电话号的网站
  • 重庆网站建设吧竞价推广是什么意思
  • 全球最受欢迎的网站排名排名第一的手机清理软件
  • 广州网站设计服务怎样自己制作网站
  • 南京外贸网站建设报价什么平台可以发广告引流
  • 哈尔滨企业建站服务商站长工具pr值查询
  • 福州做网站的公司多少钱中国网站建设公司
  • 商城网站建设的优点代写软文公司
  • 画册宣传册设计样本湖北seo关键词排名优化软件
  • 深圳网站建设外包自己的品牌怎么做加盟推广
  • 做外贸网站的公司九江seo
  • 育婴网站模板个人免费推广网站
  • 一个域名可以建几个网站互换链接的方法
  • 做关于灯饰的网站seo文章推广
  • 吉安网站建设seo神器
  • 阿里巴巴属于b2b还是b2c优化是什么意思?
  • 营销技巧 第一季嘉兴seo优化
  • 用ai做网站手机免费建站系统
  • web2.0网站设计最新国际新闻
  • 怎样做网站连接百度推广关键词匹配模式