gpt4 book ai didi

python - 将多个元素添加到字典中的集合

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

我正在尝试实现以下结构。

{0: set([1]), 1: set([2]), 2: set([0,3]), 3: set([3])}

以下是我的代码:

class Graph(object):
""" This is the graph class which will store the information regarding
the graph like vertices and edges.
"""

def __init__(self,num_vertices):
self.vertices = num_vertices
self.edges = []
self.indi_edges = ()

def enter_edges(self,source,dest):
self.indi_edges = (source, dest)
self.edges.append(self.indi_edges)

def form_graph_structure(self):
temp_dict = {}
for idx,value in enumerate(self.edges):
if value[0] in temp_dict:
print "here"
temp_dict[value[0]].update(value[1])
print "there"
temp_dict[value[0]] = set()
temp_dict[value[0]].add(value[1])
print temp_dict


def display(self):
print self.edges

g = Graph(4)
g.enter_edges(2,0)
g.enter_edges(2,3)
g.enter_edges(0,1)
g.enter_edges(1,2)
g.enter_edges(3,3)
g.form_graph_structure()

我收到以下错误

  File "DFS.py", line 20, in form_graph_structure
temp_dict[value[0]].update(value[1])
TypeError: 'int' object is not iterable

有人可以帮忙吗?

最佳答案

set.update() 需要一个 iterable 值。使用 set.add()添加一个值:

if value[0] in temp_dict:
temp_dict[value[0]].add(value[1])

与其每次都测试 value[0],不如使用 dict.setdefault()如果缺少 key ,则设置一个空集:

def form_graph_structure(self):
temp_dict = {}
for source, dest in self.edges:
temp_dict.setdefault(source, set()).add(dest)
return temp_dict

关于python - 将多个元素添加到字典中的集合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39401150/

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