# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
471198 | hoaphat1 | 경주 (Race) (IOI11_race) | C++17 | 0 ms | 0 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#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});
}*/