Предположим, мы начинаем с графика "дружбы", представленного списком кортежей,
friendships = [(0, 1), (0, 2), (1, 2), (1, 3), (2,
3), (3, 4),(4, 5), (5, 6), (5, 7), (6, 8), (7, 8), (8, 9)]
где элемент 0 является другом 1 (и, следовательно, 1 является другом 0).
Я хочу построить матрицу смежности с нуля так, чтобы она всегда работала для этого типа представления кортежей.
У меня есть следующий (отталкивающий) код Python:
def make_matrix(num_rows,num_cols,entry_fn):
return [[entry_fn(i,j)
for j in range(num_cols)]
for i in range(num_rows)]
def adjacency(connections):
new=connections+[(x[1],x[0]) for x in connections]
elements=list(set([x[0] for x in connections]+ [x[1] for x in connections]))
def test(i,j):
if (elements[i],elements[j]) in new:
return 1
else: return 0
return make_matrix(len(elements),len(elements),test)
Я знаю, что это неэффективно и очень уродливо. Есть ли более разумный способ решить эту проблему? Вывод для списка примеров, который я дал выше, должен быть
[[0, 1, 1, 0, 0, 0, 0, 0, 0, 0],
[1, 0, 1, 1, 0, 0, 0, 0, 0, 0],
[1, 1, 0, 1, 0, 0, 0, 0, 0, 0],
[0, 1, 1, 0, 1, 0, 0, 0, 0, 0],
[0, 0, 0, 1, 0, 1, 0, 0, 0, 0],
[0, 0, 0, 0, 1, 0, 1, 1, 0, 0],
[0, 0, 0, 0, 0, 1, 0, 0, 1, 0],
[0, 0, 0, 0, 0, 1, 0, 0, 1, 0],
[0, 0, 0, 0, 0, 0, 1, 1, 0, 1],
[0, 0, 0, 0, 0, 0, 0, 0, 1, 0]]
Обновление:
согласно одному из ответов, у меня есть следующее возможное решение, хотя я не знаю, лучше ли это
def adj(connections):
##step 1
temp=(set(elem[0] for elem in connections).union(
set(elem[1] for elem in connections)))
n=max(temp)+1
ans=[]
##step 2
for i,_ in enumerate(temp):
ans.append([])
for j,_ in enumerate(temp):
ans[i].append(0)
##step 3
for pair in connections:
ans[pair[0]][pair[1]]=1
ans[pair[1]][pair[0]]=1
return ans