您的位置:首页 > 其它

二叉树的序列化

2016-03-29 17:03 295 查看

题目描述

二叉树被记录成文件的过程叫做二叉树的序列化。序列化的方法有很多,这里我们采用括号序列的方法将其序列化,所谓括号序列指的是对于一个节点生成一个括号,括号内是其子树的括号序列,其中左儿子(若存在)的括号在前,右儿子(若存在)的括号在后。对于给定的树,请设计高效的算法,将其序列化。

给定一个树的根节点指针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);

}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: