本文共 883 字,大约阅读时间需要 2 分钟。
二叉树被记录成文件的过程叫做二叉树的序列化。序列化的方法有很多,这里我们采用括号序列的方法将其序列化,所谓括号序列指的是对于一个节点生成一个括号,括号内是其子树的括号序列,其中左儿子(若存在)的括号在前,右儿子(若存在)的括号在后。对于给定的树,请设计高效的算法,将其序列化。
给定一个树的根节点指针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); }}
转载地址:http://lfdii.baihongyu.com/