This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "roads.h"
#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define all(a) a.begin(), a.end()
vector<vector<vector<ll>>> dp;
vector<vector<array<ll, 2>>> graph;
vector<bool> used;
void dfs(int n, int p, int dist, int k){
vector<array<ll, 2>> d;
for(auto x : graph[n]){
if(x[0] != p){
dfs(x[0], n, x[1], k);
d.push_back({dp[x[0]][k][1] - dp[x[0]][k][0], x[0]});
}
}
sort(all(d));
ll s1 = 0;
if(graph[n].size() - k > d.size())
dp[n][k][0] = dist;
else{
for (int i = 0; i < graph[n].size() - k; i++)
s1 += dp[d[i][1]][k][1], used[d[i][1]] = 1;
for (auto x : graph[n])
if (x[0] != p and !used[x[0]])
s1 += dp[x[0]][k][0];
dp[n][k][0] = s1;
for (int i = 0; i < graph[n].size() - k; i++)
used[d[i][1]] = 0;
}
if(n != 0){
s1 = 0;
for(int i = 0; i < (int)graph[n].size() - k - 1; i ++)
s1 += dp[d[i][1]][k][1], used[d[i][1]] = 1;
s1 += dist;
for(auto x : graph[n])
if(x[0] != p and !used[x[0]])
s1 += dp[x[0]][k][0];
dp[n][k][1] = s1;
for(int i = 0; i < (int)graph[n].size() - k - 1; i ++)
used[d[i][1]] = 0;
}
}
vector<ll> minimum_closure_costs(int n, vector<int> u, vector<int> v, vector<int> w) {
graph.resize(n);
for(int i = 0; i < n - 1; i ++)
graph[u[i]].push_back({v[i], w[i]}), graph[v[i]].push_back({u[i], w[i]});
used.resize(n);
dp.resize(n, vector<vector<ll>>(n, vector<ll>(2, 0)));
for(int i = 0; i < n; i ++)
dfs(0, -1, 0, i);
vector<ll> ans(n);
for(int i = 0; i < n; i ++)
ans[i] = dp[0][i][0];
return ans;
}
Compilation message (stderr)
roads.cpp: In function 'void dfs(int, int, int, int)':
roads.cpp:25:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::array<long long int, 2> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
25 | for (int i = 0; i < graph[n].size() - k; i++)
| ~~^~~~~~~~~~~~~~~~~~~~~
roads.cpp:31:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::array<long long int, 2> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
31 | for (int i = 0; i < graph[n].size() - k; i++)
| ~~^~~~~~~~~~~~~~~~~~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |