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

Java | Leetcode Java题解之第449题序列化和反序列化二叉搜索树

题目:

题解:

public class Codec {public String serialize(TreeNode root) {List<Integer> list = new ArrayList<Integer>();postOrder(root, list);String str = list.toString();return str.substring(1, str.length() - 1);}public TreeNode deserialize(String data) {if (data.isEmpty()) {return null;}String[] arr = data.split(", ");Deque<Integer> stack = new ArrayDeque<Integer>();int length = arr.length;for (int i = 0; i < length; i++) {stack.push(Integer.parseInt(arr[i]));}return construct(Integer.MIN_VALUE, Integer.MAX_VALUE, stack);}private void postOrder(TreeNode root, List<Integer> list) {if (root == null) {return;}postOrder(root.left, list);postOrder(root.right, list);list.add(root.val);}private TreeNode construct(int lower, int upper, Deque<Integer> stack) {if (stack.isEmpty() || stack.peek() < lower || stack.peek() > upper) {return null;}int val = stack.pop();TreeNode root = new TreeNode(val);root.right = construct(val, upper, stack);root.left = construct(lower, val, stack);return root;}
}

http://www.mrgr.cn/news/40267.html

相关文章:

  • 点特征直方图 (PFH) 描述符
  • Windows系统实现双网卡同时上内外网
  • C++入门基础知识93(实例)——实例18【猴子吃桃问题】
  • 详解DHCP服务工作原理及配置案例
  • 【python进阶攻略12】C扩展
  • 时域和空域去噪
  • 力扣(leetcode)每日一题 2286 以组为单位订音乐会的门票 | 线段树
  • 力扣(leetcode)每日一题 1845 座位预约管理系统| treeSet和priority Queue的区别|线段树
  • Ajax ( 是什么、URL、axios、HTTP、快速收集表单 )Day01
  • 端点安全服务:全面的端点安全解决方案
  • 多普勒频移
  • 如何选择与运用工具提升工作效率的秘密指南
  • 毕业设计选题:基于ssm+vue+uniapp的购物系统小程序
  • fNIRS光极排布——基于fNIRS Optodes’ Location Decider (fOLD)工具包
  • OkHttp 详细使用步骤,以及异步请求和同步请求
  • 深度学习:GAN图像生成
  • ZYNQ:Hello World 实验-PS-串口打印“Hello World”
  • 【微服务】初识
  • 有效的字母异位词【字符串哈希】
  • ARM base instruction -- movk