Submission #504115

#TimeUsernameProblemLanguageResultExecution timeMemory
504115inksamuraiDeblo (COCI18_deblo)C++17
45 / 90
117 ms65540 KiB
#include <bits/stdc++.h> #define fi first #define se second #define pb push_back #define sz(a) (ll)a.size() #define all(a) a.begin(),a.end() #define rep(i,n) for(ll i=0;i<n;i++) #define crep(i,x,n) for(ll i=x;i<n;i++) #define drep(i,n) for(ll i=n-1;i>=0;i--) #define vec(...) vector<__VA_ARGS__> #define _34raRxL ios_base::sync_with_stdio(false),cin.tie(0),cout.tie(0) using namespace std; typedef long long ll; typedef long double ld; void prll(){ cout<<"\n"; } template<class te,class ...ti> void prll(const te&v, const ti&...nv) { cout<<v; if(sizeof...(nv)){ cout<<" "; prll(nv...); } } using tpii=pair<ll,pair<ll,ll>>; using pii=pair<ll,ll>; using vi=vector<ll>; using vll=vector<long long>; // ll cnt[100011][21][2]; void slv(){ ll n; cin>>n; vi a(n); rep(i,n){ cin>>a[i]; } vec(vi) adj(n); rep(i,n-1){ ll u,v; cin>>u>>v; u--,v--; adj[u].pb(v); adj[v].pb(u); } vec(vec(vi)) cnt(n,vec(vi)(22,vi(2))); vi pxor(n,-1); ll ans=0; auto dfs=[&](auto self,ll v,ll par)->void{ if(par!=-1){ pxor[v]=pxor[par]; } ll x=a[v]; ans+=x; pxor[v]^=x; for(auto u : adj[v]){ if(u!=par){ self(self,u,v); } } rep(j,22){ for(auto u : adj[v]){ if(u==par){ continue; } if(x&(1ll<<j)){ // [0,0],[1,1] ans+=(1ll<<j)*cnt[u][j][0]*cnt[v][j][0]; ans+=(1ll<<j)*cnt[u][j][1]*cnt[v][j][1]; }else{ // [0,1],[1,0] ans+=(1ll<<j)*cnt[u][j][0]*cnt[v][j][1]; ans+=(1ll<<j)*cnt[u][j][1]*cnt[v][j][0]; } if((pxor[v]^x)&(1ll<<j)){ // if(v==0 and u==1){ // prll(pxor[x],"\n"); // } ans+=(1ll<<j)*cnt[u][j][0]; }else{ ans+=(1ll<<j)*cnt[u][j][1]; } cnt[v][j][0]+=cnt[u][j][0]; cnt[v][j][1]+=cnt[u][j][1]; } cnt[v][j][bool(pxor[v]&(1ll<<j))]++; } }; dfs(dfs,0,-1); prll(ans,"\n"); } int main(){ _34raRxL; ll t=1; // cin>>t; slv(); // return 0; }

Compilation message (stderr)

deblo.cpp: In function 'int main()':
deblo.cpp:99:5: warning: unused variable 't' [-Wunused-variable]
   99 |  ll t=1;
      |     ^
#Verdict Execution timeMemoryGrader output
Fetching results...