66582023-12-15 17:30:46anonVillanyautócpp17Hibás válasz 2/60883ms4756 KiB
#include <bits/stdc++.h>

#define MAX_N 100

#define FastIO ios::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL)
#define all(x) x.begin(), x.end()

typedef long long ll;

using namespace std;

const ll INF = ~(1LL << 63);

ll N, M, K, G[MAX_N + 1][MAX_N + 1];
bool vis[MAX_N + 1];
unordered_map<ll,array<ll,2>> states;

void walk(ll node, ll k, ll cap, ll max_cap) {
    if(cap < 0)
        return;

    auto found = states.find(node);

    if(found != states.end() && ((found->second[0] > k && found->second[1] > cap) || (found->second[0] == k && found->second[1] > cap) || (found->second[0] > k && found->second[1] == cap)))
        return;

    if(found == states.end())
        states[node] = { k, cap };
    else {
        found->second[0] = max(k, found->second[0]);
        found->second[1] = max(cap, found->second[1]);
    }

    vis[node] = true;

    if(k > 0)
        walk(node, k - 1, max_cap, max_cap);

    for(ll i = 1; i <= MAX_N; i++) {
        if(G[node][i])
            walk(i, k, cap - G[node][i], max_cap);
    }
}

int main()
{
    FastIO;
    ll n1, n2, C;
    set<ll> caps;
    cin >> N >> M >> K;
    for(ll i = 0; i < M; i++) {
        cin >> n1 >> n2 >> C;
        G[n1][n2] = C;
        G[n2][n1] = C;
        caps.insert(C);
    }
    set<ll>::iterator it;
    for(it = caps.begin(); it != caps.end(); it++) {
        for(ll i = 1; i <= N; i++) {
            fill(vis + 1, vis + N + 1, false);
            states.clear();
            walk(1, K, 0, *it);
            if(!all_of(vis + 1, vis + N + 1, [](auto &a) { return a; }))
                goto next;
        }
        cout << *it << '\n';
        break;
        next:;
    }
    return 0;
}

RészfeladatÖsszpontTesztVerdiktIdőMemória
base2/60
1Elfogadva0/03ms1832 KiB
2Elfogadva0/0883ms2388 KiB
3Hibás válasz0/14ms2440 KiB
4Hibás válasz0/14ms2760 KiB
5Hibás válasz0/14ms2984 KiB
6Hibás válasz0/24ms3096 KiB
7Hibás válasz0/210ms3500 KiB
8Hibás válasz0/213ms3804 KiB
9Hibás válasz0/13ms3460 KiB
10Hibás válasz0/13ms3708 KiB
11Hibás válasz0/13ms3788 KiB
12Hibás válasz0/23ms3976 KiB
13Hibás válasz0/23ms3932 KiB
14Hibás válasz0/23ms4192 KiB
15Hibás válasz0/33ms4472 KiB
16Hibás válasz0/33ms4432 KiB
17Hibás válasz0/23ms4392 KiB
18Hibás válasz0/225ms4308 KiB
19Hibás válasz0/216ms4316 KiB
20Hibás válasz0/225ms4472 KiB
21Elfogadva2/2104ms4296 KiB
22Hibás válasz0/24ms4468 KiB
23Hibás válasz0/34ms4592 KiB
24Hibás válasz0/3222ms4568 KiB
25Hibás válasz0/3107ms4660 KiB
26Hibás válasz0/3347ms4756 KiB
27Hibás válasz0/3303ms4708 KiB
28Hibás válasz0/316ms4632 KiB
29Hibás válasz0/313ms4484 KiB
30Hibás válasz0/343ms4484 KiB