老衛帶你學---劍指offer刷題系列(61.序列化二叉樹)

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
        
        
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章