我如何 return 进行中序遍历而不只是打印它
How can I return an inorder traversal instead of just printing it
到目前为止,我的代码只打印出一个中序遍历。不过,我想return一个。
class Node:
def __init__(self, data):
self.data = data
self.left = None
self.right = None
def inorder(node):
if(node==None):
return
else:
inorder(node.left)
print(node.data)
inorder(node.right)
root = Node(1)
root.left = Node(2)
root.right = Node(3)
root.left.left = Node(4)
root.left.right = Node(5)
P.S我知道这棵树不是二叉查找树
您可以使用发电机。 yield from
递归调用和 yield
数据值。
class Node:
def __init__(self, data):
self.data = data
self.left = None
self.right = None
def inorder(node):
if node:
yield from inorder(node.left)
yield node.data
yield from inorder(node.right)
root = Node(1)
root.left = Node(2)
root.right = Node(3)
root.left.left = Node(4)
root.left.right = Node(5)
print(list(inorder(root)))
结果
[4, 2, 5, 1, 3]
如果您希望它使用列表而不是生成器。
def inorder_list(node):
accum = []
inorder_list_impl(node, accum.append)
return accum
def inorder_list_impl(node, accumulator):
if node:
inorder_list_impl(node.left, accumulator)
accumulator(node.data)
inorder_list_impl(node.right, accumulator)
您也可以使用
inorder_list_impl(root, print)
只打印值。
到目前为止,我的代码只打印出一个中序遍历。不过,我想return一个。
class Node:
def __init__(self, data):
self.data = data
self.left = None
self.right = None
def inorder(node):
if(node==None):
return
else:
inorder(node.left)
print(node.data)
inorder(node.right)
root = Node(1)
root.left = Node(2)
root.right = Node(3)
root.left.left = Node(4)
root.left.right = Node(5)
P.S我知道这棵树不是二叉查找树
您可以使用发电机。 yield from
递归调用和 yield
数据值。
class Node:
def __init__(self, data):
self.data = data
self.left = None
self.right = None
def inorder(node):
if node:
yield from inorder(node.left)
yield node.data
yield from inorder(node.right)
root = Node(1)
root.left = Node(2)
root.right = Node(3)
root.left.left = Node(4)
root.left.right = Node(5)
print(list(inorder(root)))
结果
[4, 2, 5, 1, 3]
如果您希望它使用列表而不是生成器。
def inorder_list(node):
accum = []
inorder_list_impl(node, accum.append)
return accum
def inorder_list_impl(node, accumulator):
if node:
inorder_list_impl(node.left, accumulator)
accumulator(node.data)
inorder_list_impl(node.right, accumulator)
您也可以使用
inorder_list_impl(root, print)
只打印值。