Для моего класса CS мне нужно реализовать алгоритм Прима в Java, и у меня возникли проблемы с шагом очереди приоритетов. У меня есть опыт работы с приоритетными очередями, и я понимаю, что они работают в целом, но у меня возникают проблемы с определенным шагом.
Prim(G,w,r)
For each u in V[G]
do key[u] ← ∞
π[u] ← NIL
key[r] ← 0
Q ← V[G]
While Q ≠ Ø
do u ← EXTRACT-MIN(Q)
for each v in Adj[u]
if v is in Q and w(u,v) < key[v]
then π[v] ← u
key[v] ← w(u,v)
Я создал класс Node, который содержит значение ключа (которое, как я полагаю, является самым легким ребром, подключенным к Node) и родительский узел. Моя проблема в том, что я не понимаю, как добавить узел в очередь с приоритетами. Добавление всех узлов в очередь с приоритетом не имеет смысла для меня, когда для родителя установлено значение NIL, а для ключа ∞.