Leetcode 955 Solution
This article provides solution to leetcode question 955 (complete-binary-tree-inserter).
Access this page by simply typing in "lcs 955" in your browser address bar if you have bunnylol configured.
Leetcode Question Link
https://leetcode.com/problems/complete-binary-tree-inserter
Solution
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class CBTInserter:
def __init__(self, root: TreeNode):
self.nodes = [[root]]
i = 0
while i < len(self.nodes):
for node in self.nodes[i]:
if (node.left or node.right) and i == len(self.nodes) - 1:
self.nodes.append([])
if node.left:
self.nodes[i + 1].append(node.left)
if node.right:
self.nodes[i + 1].append(node.right)
i += 1
def insert(self, v: int) -> int:
if len(self.nodes) == 1 or len(self.nodes[-1]) == len(self.nodes[-2]) * 2:
self.nodes.append([])
parent = self.nodes[-2][len(self.nodes[-1]) // 2]
if len(self.nodes[-1]) % 2 == 0:
parent.left = TreeNode(v)
self.nodes[-1].append(parent.left)
else:
parent.right = TreeNode(v)
self.nodes[-1].append(parent.right)
return parent.val
def get_root(self) -> TreeNode:
return self.nodes[0][0]
# Your CBTInserter object will be instantiated and called as such:
# obj = CBTInserter(root)
# param_1 = obj.insert(v)
# param_2 = obj.get_root()