Я деревья решений реализованы в Python в качестве словарей.Пример:
sampletree = {'spl':'foo', 'go_r':{'cut':150} , 'l':{'val':100}, 'r':{'val':200}}
У меня есть рекурсивная функция, которая печатает дерево:
def TREE_PRINT(tree, indent=''):
#is this a leaf node?
if 'val' in tree:
print str(tree['val'])
else:
#print the criteria
print 'split: '+ str(tree['spl']) + ' ' + str(tree['go_r'])
#print the branches
print indent+'L->', TREE_PRINT(tree['l'], indent+' ')
print indent+'R->', TREE_PRINT(tree['r'], indent+' ')
Как подавить None, которые печатаются при запуске функции?
TREE_PRINT(sampletree)
split: foo {'cut': 150}
L-> 100
None
R-> 200
None
Я попытался вернуть '', но затем я получил лишние разрывы строк.Я строю функцию printtree со страницы 151 в Программировании коллективного разума.