結果
問題 | No.898 tri-βutree |
ユーザー | fine |
提出日時 | 2019-10-04 21:59:31 |
言語 | C++14 (gcc 12.3.0 + boost 1.83.0) |
結果 |
AC
|
実行時間 | 205 ms / 4,000 ms |
コード長 | 2,256 bytes |
コンパイル時間 | 2,087 ms |
コンパイル使用メモリ | 172,492 KB |
実行使用メモリ | 25,984 KB |
最終ジャッジ日時 | 2024-11-08 22:04:51 |
合計ジャッジ時間 | 6,734 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 87 ms
25,984 KB |
testcase_01 | AC | 4 ms
5,888 KB |
testcase_02 | AC | 4 ms
5,760 KB |
testcase_03 | AC | 4 ms
5,888 KB |
testcase_04 | AC | 4 ms
5,888 KB |
testcase_05 | AC | 4 ms
5,760 KB |
testcase_06 | AC | 4 ms
5,888 KB |
testcase_07 | AC | 187 ms
18,816 KB |
testcase_08 | AC | 181 ms
18,712 KB |
testcase_09 | AC | 187 ms
18,816 KB |
testcase_10 | AC | 185 ms
18,716 KB |
testcase_11 | AC | 205 ms
18,688 KB |
testcase_12 | AC | 187 ms
18,688 KB |
testcase_13 | AC | 182 ms
18,688 KB |
testcase_14 | AC | 196 ms
18,816 KB |
testcase_15 | AC | 186 ms
18,712 KB |
testcase_16 | AC | 188 ms
18,688 KB |
testcase_17 | AC | 196 ms
18,816 KB |
testcase_18 | AC | 193 ms
18,688 KB |
testcase_19 | AC | 199 ms
18,716 KB |
testcase_20 | AC | 192 ms
18,816 KB |
testcase_21 | AC | 192 ms
18,688 KB |
ソースコード
#include <bits/stdc++.h> using namespace std; using ll = long long; using P = pair<int, ll>; const int MAX_V = 100000; const int MAX_LOG_V = 17; vector<P> G[MAX_V]; int root = 0; int parent[MAX_LOG_V][MAX_V]; int depth[MAX_V]; ll weights[MAX_V]; void dfs(int v, int p, int d, ll w) { parent[0][v] = p; depth[v] = d; weights[v] = w; for (int i = 0; i < G[v].size(); i++) { if (G[v][i].first != p) dfs(G[v][i].first, v, d + 1, w + G[v][i].second); } } void init(int V) { dfs(root, -1, 0, 0); for (int k = 0; k + 1 < MAX_LOG_V; k++) { for (int v = 0; v < V; v++) { if (parent[k][v] < 0) parent[k + 1][v] = -1; else parent[k + 1][v] = parent[k][parent[k][v]]; } } } int lca(int u, int v) { if (depth[u] > depth[v]) swap(u, v); for (int k = 0; k < MAX_LOG_V; k++) { if ((depth[v] - depth[u]) >> k & 1) { v = parent[k][v]; } } if (u == v) return u; for (int k = MAX_LOG_V - 1; k >= 0; k--) { if (parent[k][u] != parent[k][v]) { u = parent[k][u]; v = parent[k][v]; } } return parent[0][u]; } int main() { cin.tie(0); ios::sync_with_stdio(false); int n; cin >> n; for (int i = 1; i < n; i++) { int u, v; ll w; cin >> u >> v >> w; G[u].emplace_back(v, w); G[v].emplace_back(u, w); } init(n); int q; cin >> q; for (int i = 0; i < q; i++) { int x, y, z; cin >> x >> y >> z; int xy = lca(x, y); int yz = lca(y, z); int zx = lca(z, x); int tar = xy; int hoge = lca(xy, z); ll ans = weights[x] + weights[y] - weights[xy] * 2; ans += weights[z] + weights[xy] - weights[hoge] * 2; if (depth[tar] < depth[yz]) { tar = yz; ans = weights[y] + weights[z] - weights[yz] * 2; ans += weights[x] + weights[yz] - weights[hoge] * 2; } if (depth[tar] < depth[zx]) { tar = zx; ans = weights[z] + weights[x] - weights[zx] * 2; ans += weights[y] + weights[zx] - weights[hoge] * 2; } cout << ans << "\n"; } return 0; }