Submission #1312242

#TimeUsernameProblemLanguageResultExecution timeMemory
1312242kawhietRace (IOI11_race)C++20
Compilation error
0 ms0 KiB
#include <bits/stdc++.h>
#include "race.h"
using namespace std;

constexpr int N = 2e5 + 5;
constexpr int inf = 1e9;

vector<pair<int, int>> g[N];
int sz[N];
bool deleted[N];

map<int, int> mn;

int k, ans = inf, mx = 0;

void dfs_size(int u, int p) {
    sz[u] = 1;
    for (auto [v, w] : g[u]) {
        if (v == p || deleted[v]) continue;
        dfs_size(v, u);
        sz[u] += sz[v];
    }
}

int find_centroid(int u, int p, int n) {
    for (auto [v, w] : g[u]) {
        if (v == p || deleted[v]) continue;
        if (sz[v] * 2 > n) {
            return find_centroid(v, u, n);
        }
    }
    return u;
}

void dfs(int u, int p, int d, int sum, bool upd) {
    if (sum > k) return;
    mx = max(mx, sum);
    if (upd) {
        if (mn.count(sum)) {
            mn[sum] = min(mn[sum], d);
        } else {
            mn[sum] = d;
        }
    } else {
        if (mn.count(k - sum)) {
            ans = min(ans, d + mn[k - sum]);
        }
    }
    for (auto [v, w] : g[u]) {
        if (v == p || deleted[v]) continue;
        dfs(v, u, d + 1, sum + w, upd);
    }
}

void go(int u) {
    dfs_size(u, -1);
    int r = find_centroid(u, -1, sz[u]);
    mx = 0;
    mn[0] = 0;
    for (auto [v, w] : g[r]) {
        if (!deleted[v]) {
            dfs(v, r, 1, w, 0);
            dfs(v, r, 1, w, 1);
        }
    }
    mn.clear();
    deleted[r] = 1;
    for (auto [v, w] : g[r]) {
        if (!deleted[v]) {
            go(v);
        }
    }
}

Compilation message (stderr)

/usr/bin/ld: /tmp/ccmsgQQF.o: in function `main':
grader.cpp:(.text.startup+0x28): undefined reference to `best_path(int, int, int (*) [2], int*)'
collect2: error: ld returned 1 exit status