結果
問題 | No.872 All Tree Path |
ユーザー | Coki628 |
提出日時 | 2020-05-08 22:18:28 |
言語 | C++14 (gcc 12.3.0 + boost 1.83.0) |
結果 |
AC
|
実行時間 | 278 ms / 3,000 ms |
コード長 | 4,495 bytes |
コンパイル時間 | 1,999 ms |
コンパイル使用メモリ | 183,248 KB |
実行使用メモリ | 89,164 KB |
最終ジャッジ日時 | 2024-07-04 00:52:19 |
合計ジャッジ時間 | 5,383 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 230 ms
41,460 KB |
testcase_01 | AC | 251 ms
41,444 KB |
testcase_02 | AC | 278 ms
41,584 KB |
testcase_03 | AC | 168 ms
89,164 KB |
testcase_04 | AC | 2 ms
6,944 KB |
testcase_05 | AC | 236 ms
41,488 KB |
testcase_06 | AC | 227 ms
41,516 KB |
testcase_07 | AC | 236 ms
41,600 KB |
testcase_08 | AC | 15 ms
7,040 KB |
testcase_09 | AC | 17 ms
7,168 KB |
testcase_10 | AC | 16 ms
7,168 KB |
testcase_11 | AC | 16 ms
7,040 KB |
testcase_12 | AC | 15 ms
7,040 KB |
testcase_13 | AC | 2 ms
6,944 KB |
testcase_14 | AC | 2 ms
6,940 KB |
testcase_15 | AC | 1 ms
6,940 KB |
testcase_16 | AC | 1 ms
6,940 KB |
testcase_17 | AC | 2 ms
6,944 KB |
testcase_18 | AC | 2 ms
6,944 KB |
testcase_19 | AC | 1 ms
6,940 KB |
ソースコード
#include <bits/stdc++.h> using namespace std; typedef long long ll; typedef long double ld; typedef pair<ll, ll> pll; typedef pair<ll, int> pli; typedef pair<int, int> pii; typedef pair<ll, ld> pld; typedef pair<pii, int> ppiii; typedef pair<pii, ll> ppiil; typedef pair<pll, ll> pplll; typedef pair<pli, int> pplii; typedef vector<vector<ll>> vvl; typedef vector<vector<int>> vvi; typedef vector<vector<pll>> vvpll; #define rep(i, a, b) for (ll i=(a); i<(b); i++) #define rrep(i, a, b) for (ll i=(a); i>(b); i--) #define pb push_back #define tostr to_string #define mkp make_pair const ll INF = 1e18; const ll MOD = 1e9 + 7; void print(ld out) { cout << fixed << setprecision(12) << out << '\n'; } template<typename T> void print(T out) { cout << out << '\n'; } template<typename T1, typename T2> void print(pair<T1, T2> out) { cout << out.first << ' ' << out.second << '\n'; } template<typename T> void print(vector<T> A) { rep(i, 0, A.size()) { cout << A[i]; cout << (i == A.size()-1 ? '\n' : ' '); } } template<typename T> void print(set<T> S) { vector<T> A(S.begin(), S.end()); print(A); } template<typename T> inline bool chmax(T &x, T y) { return (y > x) ? x = y, true : false; } template<typename T> inline bool chmin(T &x, T y) { return (y < x) ? x = y, true : false; } ll sum(vector<ll> A) { ll res = 0; for (ll a: A) res += a; return res; } ll max(vector<ll> A) { ll res = -INF; for (ll a: A) chmax(res, a); return res; } ll min(vector<ll> A) { ll res = INF; for (ll a: A) chmin(res, a); return res; } ll toint(string s) { ll res = 0; for (char c : s) { res *= 10; res += (c - '0'); } return res; } int toint(char c) { return c - '0'; } char tochar(int i) { return '0' + i; } inline ll pow(int x, ll n) { ll res = 1; rep(_, 0, n) res *= x; return res; } inline ll pow(ll x, ll n, int mod) { ll res = 1; while (n > 0) { if (n & 1) { res = (res * x) % mod; } x = (x * x) % mod; n >>= 1; } return res; } inline ll floor(ll a, ll b) { if (a < 0) { return (a-b+1) / b; } else { return a / b; } } inline ll ceil(ll a, ll b) { if (a >= 0) { return (a+b-1) / b; } else { return a / b; } } int popcount(ll S) { return __builtin_popcountll(S); } ll gcd(ll a, ll b) { return __gcd(a, b); } // 全方位木DP template<typename sum_t, typename key_t> struct ReRooting { struct Edge { int to; key_t data; sum_t dp, ndp; }; using F1 = function<sum_t(sum_t, sum_t)>; using F2 = function<sum_t(sum_t, key_t)>; vector<vector<Edge>> g; vector<sum_t> subdp, dp; const sum_t ident; const F1 f1; const F2 f2; ReRooting(int V, const F1 f1, const F2 f2, const sum_t &ident) : g(V), f1(f1), f2(f2), ident(ident), subdp(V, ident), dp(V, ident) {} void add_edge(int u, int v, const key_t &d) { g[u].emplace_back((Edge) {v, d, ident, ident}); g[v].emplace_back((Edge) {u, d, ident, ident}); } void add_edge_bi(int u, int v, const key_t &d, const key_t &e) { g[u].emplace_back((Edge) {v, d, ident, ident}); g[v].emplace_back((Edge) {u, e, ident, ident}); } void dfs_sub(int idx, int par) { for(auto &e : g[idx]) { if(e.to == par) continue; dfs_sub(e.to, idx); subdp[idx] = f1(subdp[idx], f2(subdp[e.to], e.data)); } } void dfs_all(int idx, int par, const sum_t &top) { sum_t buff{ident}; for(int i = 0; i < (int) g[idx].size(); i++) { auto &e = g[idx][i]; e.ndp = buff; e.dp = f2(par == e.to ? top : subdp[e.to], e.data); buff = f1(buff, e.dp); } dp[idx] = buff; buff = ident; for(int i = (int) g[idx].size() - 1; i >= 0; i--) { auto &e = g[idx][i]; if(e.to != par) dfs_all(e.to, idx, f1(e.ndp, buff)); e.ndp = f1(e.ndp, buff); buff = f1(buff, e.dp); } } vector<sum_t> build() { dfs_sub(0, -1); dfs_all(0, -1, ident); return dp; } }; pll f1(pll a, pll b) { return mkp(a.first + b.first, a.second + b.second); } pll f2(pll a, ll x) { return mkp(a.first+1, a.second + (a.first+1)*x); } ll N; int main() { cin.tie(0); ios::sync_with_stdio(false); cin >> N; ReRooting<pll, ll> rr(N, f1, f2, mkp(0, 0)); ll a, b, c; rep(i, 0, N-1) { cin >> a >> b >> c; a--; b--; rr.add_edge(a, b, c); } vector<pll> res = rr.build(); ll ans = 0; rep(i, 0, N) ans += res[i].second; print(ans); return 0; }