제출 #471198

#제출 시각아이디문제언어결과실행 시간메모리
471198hoaphat1경주 (Race) (IOI11_race)C++17
컴파일 에러
0 ms0 KiB
#include <bits/stdc++.h> using namespace std; int best_path(int n, int k, vector<vector<int>> edges, vector<int> w) { vector<vector<pair<int, int>>> g(n); for (int i = 0; i < n - 1; i++) { g[edges[i][0]].emplace_back(edges[i][1], w[i]); g[edges[i][1]].emplace_back(edges[i][0], w[i]); } int ans = (int) 1e9; vector<map<long long, int>> s(n); vector<pair<long long, int>> offset(n); function<void(int, int)> dfs = [&](int v, int p) { s[v][0] = 0; for (auto&x : g[v]) { int u = x.first; if (u == p) continue; dfs(u, v); offset[u].first += x.second; offset[u].second++; if ((int) s[v].size() < (int) s[u].size()) { swap(s[v], s[u]); swap(offset[v], offset[u]); } for (auto& now : s[u]) { auto it = s[v].find(k - now.first - offset[v].first - offset[u].first); if (it != s[v].end()) { ans = min(ans, it->second + now.second + offset[v].second + offset[u].second); } } for (auto& now : s[u]) { int need = now.first + offset[u].first - offset[v].first; if (!s[v].count(need)) s[v][need] = (int) 1e9; s[v][need] = min(s[v][need], now.second + offset[u].second - offset[v].second); } } }; dfs(0, -1); if (ans == (int) 1e9) ans = -1; return ans; } /* int main() { ios::sync_with_stdio(false); cin.tie(0); cout << best_path(3, 3, {{0, 1}, {1, 2}}, {1, 1}); }*/

컴파일 시 표준 에러 (stderr) 메시지

/usr/bin/ld: /tmp/ccZQfa4R.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