Пример #1
0
  public DijkstraSP(EdgeWeightDigraph G, int s) throws Exception {
    edgeTo = new DirectedEdge[G.V()];
    distTo = new double[G.V()];
    pq = new IndexMinPQ<Double>(G.V());

    for (int v = 0; v < G.V(); v++) {
      distTo[v] = Double.POSITIVE_INFINITY;
    }

    distTo[s] = 0.0;

    pq.insert(s, 0.0);

    while (!pq.isEmpty()) {
      relax(G, pq.delMin());
    }
  }