标签:random binary-tree tree python
我有以下形式的随机二叉树
12
13、14
29、26、89
每个节点都有两个子节点,即(12-(13,14),13-(29,26),14-(26,89)).在这里,我需要以[[12,13,29],[12,13,26],[12,14,26],[12,14,89]]的形式返回所有可能的路径.我尝试了以下代码.我有更新列表的问题.提前致谢.
class Tree:
def __init__(self, data, left=None, right=None):
self.data = data
self.left = left
self.right = right
def __str_(self):
return '%s' % self.data
def makeList(tree, path =[]):
if(tree != None):
path.append(tree.data)
if tree.left:
path.append(makeList(tree.left, path))
if tree.right:
path.append(makeList(tree.left, path))
return path
根=树(12)
root.left =树(13)
root.right =树(14)
root.right.left =树(26)
root.left.right =树(26)
root.left.left =树(29)
root.right.right =树(86)
x = makeList(root)
解决方法:
我不知道如何使用memoized recursion解决它.但是我仍然发布我的答案,因为它可能部分解决了您的问题.
def makeList(tree):
paths = []
if not (tree.left or tree.right):
return [[tree.data]]
if tree.left:
paths.extend([[tree.data] + child for child in makeList(tree.left)])
if tree.right:
paths.extend([[tree.data] + child for child in makeList(tree.right)])
return paths
标签:random,binary-tree,tree,python 来源: https://codeday.me/bug/20191121/2050460.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。