剑指offer 面试37题
Posted yanmk
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指offer 面试37题相关的知识,希望对你有一定的参考价值。
面试37题:
题:序列化二叉树
题目:请实现两个函数,分别用来序列化和反序列化二叉树
解题思路:首先来看二叉树的序列化,二叉树的序列化就是采用前序遍历二叉树输出节点,再碰到左子节点或者右子节点为None的时候输出一个特殊字符”#”。对于反序列化,就是针对输入的一个序列构建一棵二叉树,我们可以设置一个指针先指向序列的最开始,然后把指针指向位置的数字转化为二叉树的结点,后移一个数字,继续转化为左子树和右子树。当遇到当前指向的字符为特殊字符”#”或者指针超出了序列的长度,则返回None,指针后移,继续遍历。
解题代码:
# -*- coding:utf-8 -*- # class TreeNode: # def __init__(self, x): # self.val = x # self.left = None # self.right = None class Solution: flag=-1 def Serialize(self, root): # write code here if not root: return ‘#‘ return str(root.val)+‘,‘+self.Serialize(root.left)+‘,‘+self.Serialize(root.right) def Deserialize(self, s): # write code here self.flag+=1 lis=s.split(‘,‘) if self.flag>=len(s): return None root=None if lis[self.flag]!=‘#‘: root=TreeNode(int(lis[self.flag])) root.left=self.Deserialize(s) root.right=self.Deserialize(s) return root
以上是关于剑指offer 面试37题的主要内容,如果未能解决你的问题,请参考以下文章