61.序列化二叉樹
問題:
請實現兩個函數,分別用來序列化和反序列化二叉樹
二叉樹的序列化是指:把一棵二叉樹按照某種遍歷方式的結果以某種格式保存爲字符串,從而使得內存中建立起來的二叉樹可以持久保存。序列化可以基於先序、中序、後序、層序的二叉樹遍歷方式來進行修改,序列化的結果是一個字符串,序列化時通過 某種符號表示空節點(#),以 ! 表示一個結點值的結束(value!)。
二叉樹的反序列化是指:根據某種遍歷順序得到的序列化字符串結果str,重構二叉樹。
解決:
思想:
對於序列化,我們只需要採用一種遍歷方式,將其存儲起來即可;對於反序列,我們需要先設置一個loc作爲定位指針,然後同樣利用該遍歷方式,反序列化就可以了。
python代碼:
# -*- coding:utf-8 -*-
# class TreeNode:
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution:
def __init__(self):
self.loc=-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.loc+=1
l=s.split(',')
if(self.loc>=s):
return None
root=None
if(l[self.loc]!='#'):
root=TreeNode(int(l[self.loc]))
root.left=self.Deserialize(s)
root.right=self.Deserialize(s)
return root