首页 > 解决方案 > 如何获取树的所有子节点

问题描述

我的树具有以下结构:

tree={'0':('1','2','3'), '1':('4'), '2':('5','6'), '3':(), '4':('7','8'), '8':('9','10','11')}

如何编写 Python 代码来检索特定节点的所有给定子节点?例如,如果我给它 node 4,代码应该检索7, 8, 9, 10, 11. 对于 node 2,它应该检索5, 6等等。

这就是我尝试过的。但我正在寻找有效的东西。

import queue

tree={'0':('1','2','3'), '1':('4'), '2':('5','6'), '3':(), '4':('7','8'), '8':('9','10','11')}

num = input("what you want ")

q = queue.Queue()

q.put(num)

while not q.empty():
  n = q.get()
  for s in n:
    print(s)
    if s in tree:
      q.put(tree[s])

标签: python

解决方案


推荐阅读