二叉树的序列化

二叉树的序列化,指的是将二叉树传换成唯一的字符串,一个结构对应序列化之后的而结果是唯一的,不能出现二叉树结构不同但是序列化之后字符串相同的情况!

应用:
判断两颗二叉树是否完全相同,如 M652

一般来说,将二叉树序列化成字符串的的形式有两种,一种是力扣官方的序列化方式,使用列表存储二叉树节点的值,这里不做讨论,只说转换成字符串的方法,也就是,当x是根节点时,转换后的字符串形如:

x(左子树的序列化结果)(右子树的序列化结果)

具体代码为:

def dfs(node) -> str:
    if not node:
        return ""
    #  注意join里面是一个列表,记录了三块内容+两对括号,注意将node.val转换为字符类型
    re = "".join([str(node.val), "(", dfs(node.left), ")(", dfs(node.right), ")"])
    return re

是不是简单的一批!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值