题解 | #序列化二叉树# | JAVA | DFS

序列化二叉树

http://www.nowcoder.com/practice/cf7e25aa97c04cc1a68c8f040e71fb84

采用DFS遍历
用先序遍历很简单 , 因为先序是 中 , 左, 右 , 所有用index下标控制就行了。

public class Solution {
    String Serialize(TreeNode root) {
        if (root == null) {
            return "#";
        }
        //用先序遍历很简单 , 因为先序是  中 , 左,  右 , 所有用index下标控制就行了。 
        return root.val + "," + Serialize(root.left) + "," + Serialize(root.right);
    }


    TreeNode Deserialize(String str) {
        String[] arr = str.split(",");
        return buildTree(arr);
    }

    public int index = 0;

    private TreeNode buildTree(String[] arr) {
        String curr = arr[index];
        index++;
        if (curr.equals("#")) {
            return null;
        }
        TreeNode root = new TreeNode(Integer.parseInt(curr));
        root.left = buildTree(arr);
        root.right = buildTree(arr);
        return root;
    }
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-10 14:00
林子大了什么鸟都有啊,我觉得我说的已经很客气了,阴阳谁呢
牛客62656195...:应该不是阴阳吧?你第一次注册的时候boss就说你是牛人
点赞 评论 收藏
分享
求offer的大角牛:不吃香菜
点赞 评论 收藏
分享
06-23 11:43
门头沟学院 Java
allin校招的烤冷...:我靠,今天中午我也是这个hr隔一个星期发消息给我。问的问题还是一模一样的😅
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务