Submission

Status:

PPPPPPPPPP

Subtask/Task Score:

100/100

Score: 100

User: konthaina_TH

Problemset: Fast Delivery

Language: cpp

Time: 0.002 second

Submitted On: 2026-03-06 09:36:07

#include <bits/stdc++.h>
using namespace std;
#define ll long long
const ll INF = 1e18;

int main() {
    ll n, m;
    cin >> n >> m;
    vector<pair<ll, ll>> adj[n + 1];
    vector<ll> parent(n + 1, -1);
    for (ll i = 0; i < m; i++) {
        ll u, v, w;
        cin >> u >> v >> w;
        adj[u].push_back({v, w});
    }
    ll start;
    cin >> start;
    vector<ll> dist(n + 1, INF);
    priority_queue<pair<ll, ll>, vector<pair<ll, ll>>, greater<pair<ll, ll>>> pq;
    dist[start] = 0;
    pq.push({0, start});

    while (!pq.empty()) {
        ll d = pq.top().first;
        ll u = pq.top().second;
        pq.pop();

        if (d > dist[u]) continue;

        for (auto edge : adj[u]) {
            ll v = edge.first;
            ll w = edge.second;
            if (dist[u] + w < dist[v]) {
                dist[v] = dist[u] + w;
                parent[v] = u;
                pq.push({dist[v], v});
            }
        }
    }
    for (ll i = 0; i < n; i++) { 
        if (i == start) continue;

        cout << start << " -> " << i << " ";
        
        if (dist[i] == INF) {
            cout << "(inf)" << endl;
        } else {
            cout << "(" << dist[i] << ") ";
            vector<ll> path;
            for (ll curr = i; curr != -1; curr = parent[curr]) {
                path.push_back(curr);
            }
            reverse(path.begin(), path.end());
            for (int j = 0; j < path.size(); j++) {
                cout << path[j] << (j == path.size() - 1 ? "" : " ");
            }
            cout << endl;
        }
    }

    return 0;
}