正如我的问题所说,我想知道为什么我们在Prim 算法中使用优先队列?它如何使我们免于使用幼稚的方式(是的,我听说过,但不知道为什么)。
如果有人可以逐步解释邻接列表,我将非常高兴。我正在使用 Cormen 的书。
伪代码:
Prim(G,w,r) //what is w (weight?) and r?
For each u in V[G]
do key[u] ← ∞ // what is key?
π[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)
我正在考虑使用 std::vector 然后 std::make_heap(); 作为存储边的优先级队列。