9247 2024. 02. 19 11:17:14 TuruTamas Hálózati átvitel cpp17 Időlimit túllépés 7/50 649ms 5276 KiB
#include <bits/stdc++.h>
using namespace std;

#ifdef DEBUG
ifstream in_file("minta/be2.txt");
#define input in_file
#define INTHENAMEOFGOD
#else
#define input cin
#define INTHENAMEOFGOD \
    ios::sync_with_stdio(0); \
    cin.tie(0); \
    cout.tie(0);
#endif
typedef long long ll;
typedef vector<ll> vi;
typedef vector<vi> vvi;
typedef vector<bool> vb;
typedef pair<ll, ll> pii;

ll N, M, H, K, a, b, c;
vector<vector<pii>> G;
vi s;
vector<pii> vp;

void dfs(ll x, ll h, ll seb) {
    s[x] = max(s[x], seb);
    if (h == H) {
        return;
    }
    for (pii &next : G[x]) {
        auto &p = vp[next.first];
        if (p.first < h+1 && p.second > min(seb, next.second)) {
            continue;
        } else if (p.first >= h+1 &&  p.second <= min(seb, next.second)) {
            p = {h+1, min(seb, next.second)};
        }
        dfs(next.first, h+1, min(seb, next.second));
    }
}

int main() {
    INTHENAMEOFGOD
    input >> N >> M >> K >> H;
    K--;
    G.resize(N);
    s.assign(N, -1);
    vp.assign(N, {LLONG_MAX, 0});
    
    for (ll m = 0; m < M; m++) {
        input >> a >> b >> c;
        a--; b--;
        G[a].emplace_back(b, c);
        G[b].emplace_back(a, c);
    }

    dfs(K, 0, LLONG_MAX);
    s[K] = 0;

    for (ll val : s) {
        cout << val << "\n";
    }
}
Részfeladat Összpont Teszt Verdikt Idő Memória
base 7/50
1 Elfogadva 0/0 3ms 2040 KiB
2 Elfogadva 0/0 4ms 2348 KiB
3 Elfogadva 1/1 3ms 2516 KiB
4 Elfogadva 1/1 3ms 2552 KiB
5 Elfogadva 2/2 6ms 2648 KiB
6 Időlimit túllépés 0/2 559ms 2676 KiB
7 Elfogadva 2/2 57ms 2692 KiB
8 Időlimit túllépés 0/2 563ms 2892 KiB
9 Elfogadva 1/1 104ms 3012 KiB
10 Időlimit túllépés 0/1 570ms 3016 KiB
11 Időlimit túllépés 0/1 558ms 2432 KiB
12 Időlimit túllépés 0/1 564ms 2452 KiB
13 Időlimit túllépés 0/2 566ms 2524 KiB
14 Időlimit túllépés 0/2 558ms 2804 KiB
15 Időlimit túllépés 0/2 574ms 3028 KiB
16 Időlimit túllépés 0/2 574ms 3100 KiB
17 Időlimit túllépés 0/2 580ms 3012 KiB
18 Időlimit túllépés 0/2 560ms 3328 KiB
19 Időlimit túllépés 0/2 577ms 3600 KiB
20 Időlimit túllépés 0/2 580ms 3580 KiB
21 Időlimit túllépés 0/1 577ms 3896 KiB
22 Időlimit túllépés 0/1 556ms 4176 KiB
23 Időlimit túllépés 0/1 555ms 4660 KiB
24 Időlimit túllépés 0/1 574ms 4816 KiB
25 Időlimit túllépés 0/2 643ms 4876 KiB
26 Időlimit túllépés 0/2 561ms 4800 KiB
27 Időlimit túllépés 0/2 574ms 4948 KiB
28 Időlimit túllépés 0/2 649ms 5096 KiB
29 Időlimit túllépés 0/2 570ms 5204 KiB
30 Időlimit túllépés 0/2 565ms 5240 KiB
31 Időlimit túllépés 0/2 570ms 5276 KiB
32 Időlimit túllépés 0/2 565ms 5224 KiB