1

我的树具有以下结构: tree={'0':('1','2','3'), '1':('4'), '2':('5','6' ), '3':(), '4':('7','8'), '8':('9','10','11')}

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

我刚开始学习 Python 的基础知识,但我不知道如何为非二叉树实现这一点。

4

1 回答 1

2

您可以使用队列。

获得用户请求的值后,将其推入队列。然后,当队列不为空时,弹出一个值,打印它,检查字典,如果当前值是字典中的一个键,则将这些值中的每一个添加到队列中以在下一次传递中检查它们。

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])

演示

请注意,如果您有 treetree={'0':('1'), '1':('0')}或任何其他循环引用,则此代码将永远运行。当心!

于 2019-10-13T20:54:51.067 回答