题目描述
二叉树被记录成文件的过程叫做二叉树的序列化。序列化的方法有很多,这里我们采用括号序列的方法将其序列化,所谓括号序列指的是对于一个节点生成一个括号,括号内是其子树的括号序列,其中左儿子(若存在)的括号在前,右儿子(若存在)的括号在后。对于给定的树,请设计高效的算法,将其序列化。
给定一个树的根节点指针root,请返回一个字符串,代表其序列化后的括号序列。
思路:
递归方式先序遍历二叉树,遇到中节点打印一个‘(’,然后递归遍历左右子树,子树遍历完毕打印一个‘)’。
import java.util.*;
/*
public class TreeNode {
int val = 0;
TreeNode left = null;
TreeNode right = null;
public TreeNode(int val) {
this.val = val;
}
}*/
public class TreeToSequence {
public static String f(TreeNode root,StringBuilder sb){
sb.append("(");
if(root.left!=null){
TreeNode le = root.left;
f(le,sb);
}
if(root.right!=null){
TreeNode ri = root.right;
f(ri,sb);
}
sb.append(")");
return sb.toString();
}
public String toSequence(TreeNode root) {
// write code here
StringBuilder sb = new StringBuilder();
return f(root,sb);
}
}