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

青岛制作网站软件怎样查找网站域名

青岛制作网站软件,怎样查找网站域名,购物商城网站建设,容桂佛山做app网站题目要求 序列化是将一个数据结构或者对象转换为连续的比特位的操作,进而可以将转换后的数据存储在一个文件或者内存中,同时也可以通过网络传输到另一个计算机环境,采取相反方式重构得到原数据。 请设计一个算法来实现二叉树的序列化与反序…

题目要求

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

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

 

提示:

  • 树中结点数在范围 [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.yayakq.cn/news/807594/

相关文章:

  • 项目外包+网站开发进入百度首页
  • 网站的footer怎么做网站是否有管理员权限
  • 临沂网站优化青海旅游的网站建设
  • dedecms 做影网站天津seo排名收费
  • 要想学做网站上海中心设计公司是谁
  • 南昌seo站外优化网站图片太多怎么优化
  • 泰安网站建设焦点网络大兴建设网站公司
  • 桂园精品网站建设费用兼职网站建设收费
  • 国家住房和城乡建设部中国建造师网站官网河南网站建设电话
  • 专业网站开发培训网站建设 域名业务 邮箱
  • 南和网站建设公司广东深圳网站建设微信商城运营
  • 山东信达建设有限公司网站中国建设部网站首页
  • 网站对齐原则个人介绍的网页设计模板
  • 贪玩手游官方网站seo是什么意思 部门
  • wordpress lightsns商丘网站优化
  • 品牌网站建设大概费用网络营销的方式都有哪些
  • 巴中企业网站建设沈阳和平三好街做网站
  • wordpress 行间距插件英文seo
  • 滨州网站建设项目建设流程
  • 网站制作排序如何做电商步骤
  • 网站外链有多重要杭州建设职业技术学院招聘信息网站
  • 公众号平台登陆seo网络营销招聘
  • 大型茶叶网站建设汽车最专业的网站建设
  • 上海嘉定做网站公司重庆网站建设公司哪家好
  • 免费做彩页网站wordpress全站搜索
  • 网站开发学的啥企业做淘宝客网站有哪些
  • 对亚马逊网站做简要分析与评价建设银行瓶窑支行网站
  • 国外网站注册软件宁波市江东区地块建设网站
  • 怎么在百度上能搜到自己的网站seo新站如何快速排名
  • 宁夏网站设计公司河北廊坊公布新增阳性人员轨迹