Design an algorithm to serialize and deserialize a binary tree. There is no restriction on how your serialization/deserialization algorithm should work. You just need to ensure that a binary tree can be serialized to a string and this string can be deserialized to the original tree structure.
checklist Constraints
The number of nodes in the tree is in the range [0, 10^4]. -1000 <= Node.val <= 1000