在函数中通过引用传递值以查找二进制文件中节点的级别

2024-03-28 20:06:47 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在尝试编写一个函数来查找二叉树中节点的级别。以下是我的实现:

def level_of_node(root, node, level):
    if root is None:
        return -1

    if root.data == node:
        return level

    return level_of_node(root.left, node, level+1)
    return level_of_node(root.right, node, level+1)

这是我的树:

root = Node(6)
root.left = Node(10)
root.right = Node(3)
root.left.left = Node(4)
root.left.right = Node(30)
root.left.right.left = Node(16)
root.left.right.right = Node(8)
root.right.right = Node(3)
root.right.left = Node(5)

level = 0
x = level_of_node(root, 16, level)
print x

当我调用这个函数时,它应该返回node的级别,但是它返回-1。你知道吗

我想是因为水平是通过值传递的。有人能给我推荐一个更好的递归方法吗?你知道吗


Tags: of函数rightnodereturnif节点is