gpt4 book ai didi

python - 生成图的递归算法

转载 作者:太空宇宙 更新时间:2023-11-04 06:29:00 25 4
gpt4 key购买 nike

我有一些数据库对象作为依赖项相互完全链接。我想做的是编写一个算法来检索该信息并将所有这些表示为图形。现在一个伪代码应该可以为我解决问题,然后我应该能够编写 python 实现。这似乎是一个递归算法,这就是我被困的地方!

 Input (Obj)
list = obj.getDependencies():
if list is empty:
return obj
else
for items in list:
list1 = item.getDependencies()
if list1 is empty:
return item
else:
list2 = item.getDependencies()
......

此刻我的心都炸了!!!我怎样才能重写这个算法

最佳答案

如果我理解正确,您只需要树的叶节点(那些没有更多依赖项的节点)。是这样吗?使用辅助结构使其可运行的示例:

class Struct:
def __init__(self, **entries):
self.__dict__.update(entries)

obj = Struct(
name="1",
get_dependencies=lambda: [
Struct(name="11", get_dependencies=lambda: []),
Struct(name="12", get_dependencies=lambda: [
Struct(name="121", get_dependencies=lambda: [])
])
])

def get_all_dependencies(obj):
ds = obj.get_dependencies()
if not ds:
yield obj
for o in ds:
for o2 in get_all_dependencies(o):
yield o2

print [x.name for x in get_all_dependencies(obj)]
# ['11', '121']

如果您喜欢 itertools 使之成为可能的紧凑代码,那么具有完全相同想法的不同实现:

import itertools

def flatten(it):
return itertools.chain.from_iterable(it)

def get_all_dependencies(obj):
ds = obj.get_dependencies()
return ([obj] if not ds else flatten(get_all_dependencies(o) for o in ds))

print [x.name for x in get_all_dependencies(obj)]
# ['11', '121']

关于python - 生成图的递归算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5117444/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com