示例#1
0
  private void relax(EdgeWeightDigraph G, int v) throws Exception {
    for (DirectedEdge e : G.adj(v)) {
      int w = e.to();

      if (distTo[w] > distTo[v] + e.weight()) {
        distTo[w] = distTo[v] + e.weight();
        edgeTo[w] = e;

        if (pq.contains(w)) {
          pq.changeKey(w, distTo[w]);
        } else {
          pq.increaseKey(w, distTo[w]);
        }
      }
    }
  }