以下是一个示例代码,使用递归查询返回层次结构的所有成员:
# 定义一个类表示层次结构的成员
class Member:
def __init__(self, name, children):
self.name = name
self.children = children
# 定义一个递归函数用于查询返回所有成员
def get_all_members(member):
all_members = [member.name] # 存储当前成员名字
for child in member.children: # 遍历当前成员的所有子成员
all_members.extend(get_all_members(child)) # 递归查询子成员的所有成员
return all_members
# 创建一个层次结构的示例数据
member1 = Member("A", [])
member2 = Member("B", [])
member3 = Member("C", [])
member4 = Member("D", [])
member5 = Member("E", [])
member6 = Member("F", [])
member7 = Member("G", [])
member8 = Member("H", [])
member9 = Member("I", [])
member1.children = [member2, member3]
member2.children = [member4, member5]
member3.children = [member6, member7]
member5.children = [member8, member9]
# 调用函数查询返回层次结构的所有成员
all_members = get_all_members(member1)
print(all_members)
运行以上代码,将会输出以下结果:
['A', 'B', 'D', 'E', 'H', 'I', 'C', 'F', 'G']
这个示例中,我们通过创建一个Member
类来表示层次结构的成员,每个成员有一个name
属性和一个children
属性,用于存储子成员。然后,我们定义了一个递归函数get_all_members
来查询返回所有成员。该函数首先将当前成员的名字添加到结果列表中,然后递归调用自身来查询子成员,并将子成员的结果添加到结果列表中。最后,我们使用示例数据创建一个层次结构,并调用get_all_members
函数来查询返回所有成员。结果列表将包含层次结构中所有成员的名字。