# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
56551 | 2018-07-11T15:54:43 Z | admin | Islands (IOI08_islands) | C++14 | 819 ms | 53312 KB |
#include <bits/stdc++.h> using namespace std; using ll = long long; const int N = 1000010; const ll INF = 1e18; ll par[N], len[N], deg[N], h1[N], h2[N], dp[N]; int main() { int n; scanf("%d", &n); for (int i = 1; i <= n; ++i) { int v, w; scanf("%d%d", &v, &w); par[i] = v; len[i] = w; ++deg[v]; } queue<int> Q; for (int i = 1; i <= n; ++i) { if (deg[i] == 0) Q.push(i); } while (!Q.empty()) { int u = Q.front(); Q.pop(); int v = par[u]; ll w = len[u]; if (h1[u]+w > h1[v]) { h2[v] = h1[v]; h1[v] = h1[u]+w; } else if (h1[u]+w > h2[v]) { h2[v] = h1[u]+w; } dp[u] = max(dp[u], h1[u]+h2[u]); dp[v] = max(dp[v], dp[u]); if (--deg[v] == 0) Q.push(v); } ll ttans = 0; for (int i = 1; i <= n; ++i) { if (deg[i] == 1) { int u = i; vector<int> cyc; ll ttd = 0; do { cyc.push_back(u); deg[u] = 0; ttd += len[u]; u = par[u]; } while (u != i); ll mxm = -INF, mxp = -INF, d = 0, ans = -INF; for (auto u : cyc) { dp[u] = max(dp[u], h1[u]+h2[u]); ans = max(ans, dp[u]); ans = max(ans, h1[u]+d+mxm); ans = max(ans, h1[u]-d+ttd+mxp); mxm = max(mxm, h1[u]-d); mxp = max(mxp, h1[u]+d); d += len[u]; } ttans += ans; } } printf("%lld\n", ttans); return 0; }
Compilation message
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 3 ms | 376 KB | Output is correct |
2 | Correct | 2 ms | 484 KB | Output is correct |
3 | Correct | 3 ms | 560 KB | Output is correct |
4 | Correct | 3 ms | 564 KB | Output is correct |
5 | Correct | 3 ms | 564 KB | Output is correct |
6 | Correct | 2 ms | 564 KB | Output is correct |
7 | Correct | 2 ms | 564 KB | Output is correct |
8 | Correct | 3 ms | 564 KB | Output is correct |
9 | Correct | 2 ms | 564 KB | Output is correct |
10 | Correct | 2 ms | 592 KB | Output is correct |
11 | Correct | 2 ms | 592 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 3 ms | 612 KB | Output is correct |
2 | Correct | 3 ms | 616 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 4 ms | 740 KB | Output is correct |
2 | Correct | 4 ms | 740 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 9 ms | 1380 KB | Output is correct |
2 | Correct | 15 ms | 2404 KB | Output is correct |
3 | Correct | 13 ms | 2404 KB | Output is correct |
4 | Correct | 9 ms | 2404 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 22 ms | 3172 KB | Output is correct |
2 | Correct | 41 ms | 5092 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 91 ms | 10512 KB | Output is correct |
2 | Correct | 68 ms | 10512 KB | Output is correct |
3 | Correct | 105 ms | 13844 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 130 ms | 18668 KB | Output is correct |
2 | Correct | 172 ms | 26340 KB | Output is correct |
3 | Correct | 182 ms | 26340 KB | Output is correct |
4 | Correct | 208 ms | 33600 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 312 ms | 33600 KB | Output is correct |
2 | Correct | 460 ms | 40060 KB | Output is correct |
3 | Correct | 258 ms | 40060 KB | Output is correct |
4 | Correct | 435 ms | 50596 KB | Output is correct |
5 | Correct | 363 ms | 51680 KB | Output is correct |
6 | Correct | 819 ms | 51680 KB | Output is correct |
7 | Correct | 364 ms | 53312 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 361 ms | 53312 KB | Output is correct |
2 | Correct | 353 ms | 53312 KB | Output is correct |
3 | Correct | 542 ms | 53312 KB | Output is correct |
4 | Correct | 367 ms | 53312 KB | Output is correct |
5 | Correct | 396 ms | 53312 KB | Output is correct |
6 | Correct | 373 ms | 53312 KB | Output is correct |
7 | Correct | 798 ms | 53312 KB | Output is correct |