我想定义一个函数,将具有常见组件的列表列表打印为树。
例如,
lst = [[1, 2, 'a'], [1, 2, 'b'], [1, 1, 'a'], [1, 1, 'b'], [2, 2, 'a']]
build_tree(lst)
应打印:
1
1
a
b
2
b
2
2
a
我写了以下代码。
def build_tree(lst):
if len(lst[0]) == 1:
for e in lst:
return str(e[0])
current = lst[0][0]
seen = []
tree = ''
for e in lst:
if e[0] != current:
tree += str(current)
tree += build_tree(seen)
current = e[0]
seen = []
seen.append(e[1:])
return tree
但是返回的结果是胡说八道。
答案 0 :(得分:1)
解决此问题的一种方法是将列表更改为树结构,然后遍历该树以构建数据的字符串表示形式
from collections import defaultdict
tree = lambda: defaultdict(tree)
lst = [[1, 2, 'a'], [1, 2, 'b'], [1, 1, 'a'], [1, 1, 'b'], [2, 2, 'a']]
def make_tree(lst):
d = tree()
for x in lst:
curr = d
for item in x:
curr = curr[item]
return d
d = make_tree(lst)
def make_strs(d, indent=0):
strs = []
for k, v in d.items():
strs.append(' ' * indent + str(k))
strs.extend(make_strs(v, indent+1))
return strs
def print_tree(d):
print('\n'.join(make_strs(d)))
print_tree(d)
打印
1
2
a
b
1
a
b
2
2
a