Serialize and Deserialize BST/N-ary
当这是一个Binary Search Tree时
from collections import deque
import sys
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Codec:
def serialize(self, root: TreeNode) -> str:
"""Encodes a tree to a single string.
"""
if root == None:
return ""
self.vals = []
def dfs(node):
if node == None:
return
self.vals.append(node.val)
dfs(node.left)
dfs(node.right)
dfs(root)
return " ".join(map(str,self.vals))
def deserialize(self, data: str) -> TreeNode:
"""Decodes your encoded data to tree.
"""
if data == "":
return None
vals = deque([int(val) for val in data.split(" ")])
def builder(mmin,mmax):
if vals and mmin < vals[0] < mmax:
curr = vals.popleft()
root = TreeNode(curr)
root.left = builder(mmin,curr)
root.right = builder(curr,mmax)
return root
return None
return builder(-sys.maxsize,sys.maxsize)当这是一个Binary Tree时
Last updated