Submission

Status:

PPPPP-PPP-

Subtask/Task Score:

80/100

Score: 80

User: konthaina_TH

Problemset: Fast Delivery

Language: cpp

Time: 0.003 second

Submitted On: 2026-03-04 09:25:18

#include <bits/stdc++.h>
using namespace std;

const int INF = 1e9;

int main() {
    int n, m;
    cin >> n >> m;
    vector<pair<int, int>> adj[n + 1];
    vector<int> parent(n + 1, -1);
    for (int i = 0; i < m; i++) {
        int u, v, w;
        cin >> u >> v >> w;
        adj[u].push_back({v, w});
    }
    int start;
    cin >> start;
    vector<int> dist(n + 1, INF);
    priority_queue<pair<int, int>, vector<pair<int, int>>, greater<pair<int, int>>> pq;
    dist[start] = 0;
    pq.push({0, start});
    int cnt = 1;
    while (!pq.empty()) {
        int d = pq.top().first;
        int u = pq.top().second;
        pq.pop();

        if (d > dist[u]) continue;

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

            }
            else {
                cout << start << " -> " << cnt << " (" << "inf" << ") " << "\n";
                cnt = i;
            }
        }
        cout << start << " -> " << i << " (" << dist[i] << ") ";
        cnt++;
        vector<int> path;
        for (int curr = i; curr != -1; curr = parent[curr]) {
            path.push_back(curr);
        }
        reverse(path.begin(), path.end());
        for (int node : path) {
            cout << node << " ";
        }
        cout << endl;
    }

    return 0;
}