我试图解决以下问题:找到树中最重节点的权重,并将该节点表示为列表。这是我想出的解决方案,但我相当确定它是一个非常混乱的解决方案。在给定的类框架内更有效地处理它的任何建议吗?
给定类:
class Tree_node():
def __init__(self,key,val):
self.key=key
self.val=val
self.left=None
self.right=None
def __repr__(self):
return "[" + str(self.left) + " " + str(self.key) + " " + \
str(self.val) + " " + str(self.right) + "]"
我计算最重路径的权重:
def weight(node):
if node == None:
return 0
if weight(node.left)>weight(node.right):
return node.val+weight(node.left)
else:
return node.val+weight(node.right)
然后我尝试将最重的路径返回为列表:
def heavy_path(node):
if node==None:
return []
elif node.val+weight(node.left)> node.val+weight(node.right):
return [node.val] + filter_values(path_values(node.left))
else:return [node.val] + filter_values(path_values(node.right))
def path_values(node):
if node == None:
return 0
return [node.val,path_values(node.left),path_values(node.right)]
def filter_values (node):
values = []
sub_lists = []
if node != 0:
for value in node:
if isinstance(value, list):
sub_lists = filter_values(value)
else:
if value != 0:
values.append(value)
return values+sub_lists
给定一个类似于[[None a 7 None] b 5 [[None c 8 None] d 3 None]]的树结构:
>>> weight(t)
16
>>> heavy_path(t)
[5, 3, 8]
有什么更好的方法来做这件事吗?
heavy_path()
应该被递归调用,但我没有看到递归。 - Richard