#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define fi first
#define se second
#define int long long
typedef pair<int,int> pii;
const int MAXN = 2e5 +5;
int ans2 =0, total =0;
vector <int> adj[MAXN];
vector <int> a(MAXN), sum(MAXN), ans(MAXN);
//bool vis[MAXN];
void dfs(int x, int p, int h){
ans[1] += h*a[x];
sum[x] = a[x];
for (auto i : adj[x]){
if (i != p) {
dfs(i, x, h+1);
sum[x] += sum[i];
}
}
}
void dfs2(int x, int p){
if ( x != 1){
ans[x] = ans[p] - sum[x] + total- sum[x];
}
ans2 = max(ans2, ans[x]);
for (auto i : adj[x]){
if(i != p) {
dfs2(i, x);
}
}
}
signed main(){
ios_base::sync_with_stdio(0); cin.tie(0);
int n;
cin >> n;
for (int i =1; i <= n; i++){
cin >> a[i];
total += a[i];
}
for (int i =1; i <= n-1; i++){
int x, y;
cin >> x >> y;
adj[x].push_back(y);
adj[y].push_back(x);
}
dfs(1, 0, 0);
dfs2(1, 0);
cout << ans2;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7IAojZGVmaW5lIGxsIGxvbmcgbG9uZwojZGVmaW5lIGZpIGZpcnN0CiNkZWZpbmUgc2Ugc2Vjb25kCiNkZWZpbmUgaW50IGxvbmcgbG9uZwp0eXBlZGVmIHBhaXI8aW50LGludD4gcGlpOwpjb25zdCBpbnQgTUFYTiA9IDJlNSArNTsKCmludCAgYW5zMiA9MCwgIHRvdGFsID0wOwp2ZWN0b3IgPGludD4gYWRqW01BWE5dOwp2ZWN0b3IgPGludD4gYShNQVhOKSwgc3VtKE1BWE4pLCBhbnMoTUFYTik7Ci8vYm9vbCB2aXNbTUFYTl07Cgp2b2lkIGRmcyhpbnQgeCwgaW50IHAsIGludCBoKXsKICAgIGFuc1sxXSArPSBoKmFbeF07CiAgICBzdW1beF0gPSBhW3hdOwogICAgCiAgICBmb3IgKGF1dG8gaSA6IGFkalt4XSl7CiAgICAgICAgaWYgKGkgIT0gcCkgewogICAgICAgIGRmcyhpLCB4LCBoKzEpOwogICAgICAgIHN1bVt4XSArPSBzdW1baV07Cn0KICAgIH0KfQoKdm9pZCBkZnMyKGludCB4LCBpbnQgcCl7CiAgIGlmICggeCAhPSAxKXsKICAgICAgIGFuc1t4XSA9IGFuc1twXSAtIHN1bVt4XSArIHRvdGFsLSBzdW1beF07IAogICB9CiAgIAogICBhbnMyID0gbWF4KGFuczIsIGFuc1t4XSk7CiAgIAogICBmb3IgKGF1dG8gaSA6IGFkalt4XSl7CiAgICAgICBpZihpICE9IHApIHsKICAgICAgIGRmczIoaSwgeCk7CiAgIH0KfQp9CnNpZ25lZCBtYWluKCl7Cmlvc19iYXNlOjpzeW5jX3dpdGhfc3RkaW8oMCk7IGNpbi50aWUoMCk7CmludCBuOwogICAgY2luID4+IG47CgoKICAgIGZvciAoaW50IGkgPTE7IGkgPD0gbjsgaSsrKXsKICAgICAgICBjaW4gPj4gYVtpXTsKICAgICAgICB0b3RhbCArPSBhW2ldOwogICAgfQogICAgZm9yIChpbnQgaSA9MTsgaSA8PSBuLTE7IGkrKyl7CiAgICAgICAgaW50IHgsIHk7CiAgICAgICAgY2luID4+IHggPj4geTsKICAgICAgICBhZGpbeF0ucHVzaF9iYWNrKHkpOwogICAgICAgIGFkalt5XS5wdXNoX2JhY2soeCk7CiAgICB9CiAgICAKCiAgICBkZnMoMSwgMCwgMCk7CiAgICBkZnMyKDEsIDApOwogICAgY291dCA8PCBhbnMyOwp9