def add_edge(self, parent, child): parent.children.append(child) child.parent = parent
def last_local_update(self): for node in self.nodes: if node.parent is None: self.dfs(node)
# Update mata ka index if node.parent: node.parent.index = max(node.parent.index, node.index + 1) index of ek chalis ki last local updated
def dfs(self, node): # Update node ka index node.index = len(node.children)
# Example usage chalis = Chalis() node1 = chalis.add_node(1) node2 = chalis.add_node(2) node3 = chalis.add_node(3) def add_edge(self, parent, child): parent
# Update bacchon ka index for child in node.children: self.dfs(child) node.index = max(node.index, child.index + 1)
class Chalis: def __init__(self): self.nodes = [] node.index + 1) def dfs(self
chalis.add_edge(node1, node2) chalis.add_edge(node1, node3)
def add_edge(self, parent, child): parent.children.append(child) child.parent = parent
def last_local_update(self): for node in self.nodes: if node.parent is None: self.dfs(node)
# Update mata ka index if node.parent: node.parent.index = max(node.parent.index, node.index + 1)
def dfs(self, node): # Update node ka index node.index = len(node.children)
# Example usage chalis = Chalis() node1 = chalis.add_node(1) node2 = chalis.add_node(2) node3 = chalis.add_node(3)
# Update bacchon ka index for child in node.children: self.dfs(child) node.index = max(node.index, child.index + 1)
class Chalis: def __init__(self): self.nodes = []
chalis.add_edge(node1, node2) chalis.add_edge(node1, node3)