제출 #864467

#제출 시각아이디문제언어결과실행 시간메모리
864467truongdoan2012Putovanje (COCI20_putovanje)C++17
25 / 110
64 ms24328 KiB
#include <bits/stdc++.h> using namespace std; #ifdef LOCAL #include "algo/debug.h" #else #define debug(...) 42 #endif using i64 = long long; const int N = 1e5 + 10; int up[20][N], tin[N], tout[N], t; struct edge { int to; i64 c1, c2; }; vector<edge> g[N]; void dfs(int u, int p) { up[0][u] = p; tin[u] = t++; for (int i = 1; i < 20; i++) { up[i][u] = up[i - 1][up[i - 1][u]]; } for (auto v : g[u]) { if (v.to == p) continue; dfs(v.to, u); } tout[u] = t++; } int n; bool line(int u, int v) { return tin[u] <= tin[v] && tout[u] >= tout[v]; } int lca(int u, int v) { if (line(u, v)) return u; if (line(v, u)) return v; for (int i = 19; i >= 0; i--) { if (!line(up[i][u], v)) { u = up[i][u]; v = up[i][v]; } } return up[0][u]; } i64 dp[N]; i64 ans = 0; void calc(int u, int p) { for (auto v : g[u]) { if (v.to == p) continue; calc(v.to, u); ans += min(v.c1 * dp[v.to], v.c2); dp[u] += dp[v.to]; } } void solve() { cin >> n; for (int i = 0; i < n - 1; i++) { int a, b, c1, c2; cin >> a >> b >> c1 >> c2; g[a].push_back({b, c1, c2}); g[b].push_back({a, c1, c2}); } dfs(1, 1); for (int i = 1; i < n; i++) { dp[i]++; dp[i + 1]++; dp[lca(i, i + 1)] -= 2; } calc(1, 1); for (int i = 0; i < n; i++) { debug(dp[i]); } cout << ans; } int main() { cin.tie(nullptr) -> sync_with_stdio(false); int TC = 1; //cin >> TC; while (TC--) { solve(); } }

컴파일 시 표준 에러 (stderr) 메시지

putovanje.cpp: In function 'void solve()':
putovanje.cpp:8:20: warning: statement has no effect [-Wunused-value]
    8 | #define debug(...) 42
      |                    ^~
putovanje.cpp:81:5: note: in expansion of macro 'debug'
   81 |     debug(dp[i]);
      |     ^~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...