# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
965334 | MisterReaper | Harbingers (CEOI09_harbingers) | C++17 | 0 ms | 0 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using i64 = long long;
constexpr int maxN = 1E5 + 5;
constexpr i64 INF = 1E18;
int N;
std::vector<std::pair<int, int>> adj[maxN];
int S[maxN], V[maxN], par[maxN], w[maxN];
i64 dp[maxN];
void dfs(int v) {
i64 d = 0;
int u = v;
while(u != 1) {
d += w[u];
u = par[u];
dp[v] = std::min(dp[v], dp[u] + 1LL * d * V[v] + S[v]);
}
for(auto [u, w] : adj[v]) {
if(u == par[v]) {
continue;
}
::w[u] = w;
par[u] = v;
dfs(u);
}
}
signed main() {
std::ios::sync_with_stdio(false);
std::cin.tie(nullptr);
#ifndef LOCAL
freopen("harbingers.in", 'r', std::stdin);
freopen("harbingers.out", 'w', std::stdout);
#endif
std::cin >> N;
for(int i = 1; i <= N - 1; i++) {
int A, B, W;
std::cin >> A >> B >> W;
adj[A].emplace_back(B, W);
adj[B].emplace_back(A, W);
}
for(int i = 2; i <= N; i++) {
std::cin >> S[i] >> V[i];
}
std::fill_n(&dp[1], N, INF);
dp[1] = 0;
par[1] = 1;
dfs(1);
for(int i = 2; i <= N; i++) {
std::cout << dp[i] << " \n"[i == N];
}
return 0;
}