#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; using ll = long long; constexpr int INF = 1001001001; // constexpr int mod = 1000000007; constexpr int mod = 998244353; template inline bool chmax(T& x, T y){ if(x < y){ x = y; return true; } return false; } template inline bool chmin(T& x, T y){ if(x > y){ x = y; return true; } return false; } int main(){ ios::sync_with_stdio(false); cin.tie(nullptr); int N, M, S, G; cin >> N >> M >> S >> G; using edge = pair; vector> g(N); for(int i = 0; i < M; ++i){ int a, b, c; cin >> a >> b >> c; g[a].emplace_back(b, c); g[b].emplace_back(a, c); } vector dist(N, INF), restore(N, N); priority_queue, greater> que; dist[S] = 0; que.emplace(0, S); while(!que.empty()){ auto [d, from] = que.top(); que.pop(); if(d > dist[from]) continue; for(auto [to, cost] : g[from]){ if(chmin(dist[to], dist[from] + cost)){ que.emplace(dist[to], to); restore[to] = from; } else if(dist[to] == dist[from] + cost){ chmin(restore[to], from); } } } vector ord; while(G != S){ ord.emplace_back(G); G = restore[G]; } ord.emplace_back(S); reverse(begin(ord), end(ord)); int V = ord.size(); for(int i = 0; i < V; ++i){ cout << ord[i] << (i == V - 1 ? '\n' : ' '); } return 0; }