序列化二叉树
题目形容
请实现两个函数,别离用来序列化和反序列化二叉树。
- 二叉树的序列化是指:把一棵二叉树依照某种遍历形式的后果以某种格局保留为字符串,从而使得内存中建设起来的二叉树能够长久保留。
- 序列化能够基于先序、中序、后序、层序的二叉树遍历形式来进行批改,序列化的后果是一个字符串,序列化时通过
- 某种符号示意空节点(#),以!示意一个结点值的完结(value!)。
- 二叉树的反序列化是指:依据某种遍历程序失去的序列化字符串后果 str,重构二叉树。
- 例如,咱们能够把一个只有根节点为 1 的二叉树序列化为 ”1,”,而后通过本人的函数来解析回这个二叉树
题目链接 : 序列化二叉树
代码
/**
* 题目:序列化二叉树
* 题目形容
* 请实现两个函数,别离用来序列化和反序列化二叉树
* <p>
* 二叉树的序列化是指:把一棵二叉树依照某种遍历形式的后果以某种格局保留为字符串,从而使得内存中建设起来的二叉树能够长久保留。* 序列化能够基于先序、中序、后序、层序的二叉树遍历形式来进行批改,序列化的后果是一个字符串,序列化时通过
* 某种符号示意空节点(#),以!示意一个结点值的完结(value!)。* <p>
* 二叉树的反序列化是指:依据某种遍历程序失去的序列化字符串后果 str,重构二叉树。* <p>
* 例如,咱们能够把一个只有根节点为 1 的二叉树序列化为 "1,",而后通过本人的函数来解析回这个二叉树
* <p>
* 题目链接:* https://www.nowcoder.com/practice/cf7e25aa97c04cc1a68c8f040e71fb84?tpId=13&&tqId=11214&rp=1&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking
*/
public class Jz61 {
private String deserializeStr;
/**
* 先序遍历
*
* @param root
* @return
*/
String serialize(TreeNode root) {if (root == null) {return "#";}
return root.val + "" + serialize(root.left) +" " + serialize(root.right);
}
TreeNode deserialize(String str) {
deserializeStr = str;
return deserialize();}
private TreeNode deserialize() {if (deserializeStr.length() == 0) {return null;}
int index = deserializeStr.indexOf(" ");
String node = index == -1 ? deserializeStr : deserializeStr.substring(0, index);
deserializeStr = index == -1 ? "" : deserializeStr.substring(index + 1);
if (node.equals("#")) {return null;}
int val = Integer.valueOf(node);
TreeNode t = new TreeNode(val);
t.left = deserialize();
t.right = deserialize();
return t;
}
public static void main(String[] args) {TreeNode root = TreeNode.testCase1();
Jz61 jz61 = new Jz61();
String serialize = jz61.serialize(root);
System.out.println(serialize);
TreeNode rootCopy = jz61.deserialize(serialize);
System.out.println(rootCopy);
}
}
【每日寄语】愿你明天温顺,优良,可恶,果决,一干二净。