二叉树的序列化

题目描述

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

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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值