题解 | #二叉树序列化与反序列化#

序列化二叉树

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

/*
public class TreeNode {
    int val = 0;
    TreeNode left = null;
    TreeNode right = null;

    public TreeNode(int val) {
        this.val = val;

    }

}
*/
public class Solution {
    String Serialize(TreeNode root) {
        if(root == null) {
            return "#_" ;
        }
        return root.val + "_" + Serialize(root.left) + Serialize(root.right) ;
    }
    int index = 0 ;
    TreeNode Deserialize(String str) {
        if(index >= str.length()) {//索引超过直接返回null
            return null ;
        }
        if(str.charAt(index) == '#') {
            index+=2 ;//讲索引位置移动到下一个有效字符
            return null ;
        }
        int i = index ;//寻找完整的数
        while(str.charAt(i) >= '0' && str.charAt(i) <= '9') {
            i++ ;
        }
        TreeNode root = new TreeNode(Integer.parseInt(str.substring(index,i))) ;//构造完整数的节点
        index = i+1 ;//讲索引位置移动到下一个有效字符
        root.left = Deserialize(str) ;//递归
        root.right = Deserialize(str) ;
        return root ;
    }
    
}

一个菜鸟的算法刷题记录 文章被收录于专栏

分享一个菜鸟的成长记录

全部评论

相关推荐

门口唉提是地铁杀:之前b站被一个游戏demo深深的吸引了。看up主页发现是个初创公司,而且还在招人,也是一天60。二面的时候要我做一个登录验证和传输文件两个微服务,做完要我推到github仓库,还要我加上jaeger和一堆运维工具做性能测试并且面试的时候投屏演示。我傻乎乎的做完以后人家跟我说一句现在暂时不招人,1分钱没拿到全是白干
你的秋招第一场笔试是哪家
点赞 评论 收藏
分享
06-12 16:23
已编辑
小米_软件开发(准入职员工)
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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