# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
87708 | win11905 | Deblo (COCI18_deblo) | C++11 | 341 ms | 13172 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
/**
* code generated by JHelper
* More info: https://github.com/AlexeyDmitriev/JHelper
* @author win11905
*/
#include <bits/stdc++.h>
#define all(x) (x).begin(), (x).end()
#define long long long
#define pii pair<int, int>
#define x first
#define y second
using namespace std;
const long MOD = 1e9+7, LINF = 1e18 + 1e16;
const int INF = 1e9+1;
const double EPS = 1e-10;
const int dx[4] = {-1, 0, 1, 0}, dy[4] = {0, 1, 0, -1};
const int N = 1e5+5;
class deblo {
private:
int n, A[N], dp[N];
long ans;
bool check[N];
vector<int> g[N];
void find(int u, int p, int sz, pii &ret) {
dp[u] = 1;
int mx = 0;
for(int v : g[u]) if(v != p and !check[v]) {
find(v, u, sz, ret);
dp[u] += dp[v], mx = max(mx, dp[v]);
}
mx = max(mx, sz - dp[u]);
if(mx < ret.x) ret = pii(mx, u);
}
int step[2][22];
void upd(int val) {
for(int i = 21; ~i; --i) step[val >> i & 1][i]++;
}
long get(int val) {
long sum = 0;
for(int i = 21; ~i; --i) sum += (1ll << i) * step[(val >> i & 1) ^ 1][i];
return sum;
}
void dfs(int u, int p, int d, bool st) {
if(st) ans += get(d);
else upd(d);
for(int v : g[u]) if(v != p and !check[v]) dfs(v, u, d ^ A[v], st);
}
void solve(int u, int sz) {
memset(step, 0, sizeof step);
pii ret(sz, -1);
find(u, 0, sz, ret);
check[u = ret.y] = true;
upd(A[u]);
for(int v : g[u]) if(!check[v]) {
dfs(v, u, A[v], true);
dfs(v, u, A[u] ^ A[v], false);
}
for(int v : g[u]) if(!check[v]) solve(v, dp[v] > dp[u] ? sz - dp[u] : dp[v]);
}
public:
void solve(istream& cin, ostream& cout) {
cin >> n;
for(int i = 1; i <= n; ++i) cin >> A[i], ans += A[i];
for(int i = 1, u, v; i < n; ++i) {
cin >> u >> v;
g[u].emplace_back(v), g[v].emplace_back(u);
}
solve(1, n);
cout << ans << endl;
}
};
class Solver {
public:
void solve(std::istream& in, std::ostream& out) {
deblo *obj = new deblo();
obj->solve(in, out);
}
};
int main() {
ios::sync_with_stdio(false);
cin.tie(0);
Solver solver;
std::istream& in(std::cin);
std::ostream& out(std::cout);
solver.solve(in, out);
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |