#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
using namespace std;
using namespace __gnu_pbds;
#define fi first
#define se second
#define mp make_pair
#define pb push_back
#define fbo find_by_order
#define ook order_of_key
typedef long long ll;
typedef pair<ll,ll> ii;
typedef vector<int> vi;
typedef long double ld;
typedef tree<int, null_type, less<int>, rb_tree_tag, tree_order_statistics_node_update> pbds;
typedef set<int>::iterator sit;
typedef map<int,int>::iterator mit;
typedef vector<int>::iterator vit;
const int INF = int(1e9);
struct SCC
{
vector<vector<int> > vec;
int index;
vector<int> idx;
vector<int> lowlink;
vector<bool> onstack;
stack<int> s;
vector<int> sccidx;
int scccnt;
//lower sccidx means appear later
void init(int n)
{
idx.assign(n,-1);
index = 0;
onstack.assign(n,0);
lowlink.assign(n,INF);
while(!s.empty()) s.pop();
sccidx.assign(n,-1);
scccnt = 0;
vec.clear();
vec.resize(n);
}
void addedge(int u, int v) //u -> v
{
vec[u].pb(v);
}
void connect(int u)
{
idx[u] = index;
lowlink[u] = index;
index++;
s.push(u);
onstack[u] = true;
for(int i = 0; i < vec[u].size(); i++)
{
int v = vec[u][i];
if(idx[v] == -1)
{
connect(v);
lowlink[u] = min(lowlink[u], lowlink[v]);
}
else if(onstack[v])
{
lowlink[u] = min(lowlink[u], idx[v]);
}
}
if(lowlink[u] == idx[u])
{
while(1)
{
int v = s.top();
s.pop();
onstack[v] = false;
sccidx[v] = scccnt;
if(v == u) break;
}
scccnt++;
}
}
void tarjan()
{
for(int i = 0; i < vec.size(); i++)
{
if(idx[i] == -1)
{
connect(i);
}
}
}
};
SCC scc;
const int N = 300000;
ll cnt[300001];
ll dp[300001];
vi adj[300001];
vector<ii> edges;
int main()
{
ios_base::sync_with_stdio(0); cin.tie(0);
int n, m; cin>>n>>m;
scc.init(n);
for(int i = 0; i < n; i++)
{
cin>>cnt[i];
}
for(int i = 0; i < m; i++)
{
int u, v;
cin>>u>>v;
u--; v--;
edges.pb(mp(u,v));
scc.addedge(u,v);
}
scc.tarjan();
int maxidx = 0;
for(int i = 0; i < n; i++)
{
dp[scc.sccidx[i]] += cnt[i];
maxidx = max(maxidx, scc.sccidx[i]);
}
for(int i = 0; i < m; i++)
{
int l = scc.sccidx[edges[i].fi];
int r = scc.sccidx[edges[i].se];
if(l==r) continue;
adj[l].pb(r);
assert(l>r);
}
//larger sccidx -> lower sccidx
for(int i = 0; i <= maxidx; i++)
{
ll cnt = dp[i];
for(int j = 0; j < adj[i].size(); j++)
{
int u = adj[i][j];
dp[i] = max(cnt+dp[u], dp[i]);
}
}
for(int i = 0; i < n; i++)
{
cout << dp[scc.sccidx[i]] << ' ';
}
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CiNpbmNsdWRlIDxleHQvcGJfZHMvYXNzb2NfY29udGFpbmVyLmhwcD4KI2luY2x1ZGUgPGV4dC9wYl9kcy90cmVlX3BvbGljeS5ocHA+CiAKdXNpbmcgbmFtZXNwYWNlIHN0ZDsKdXNpbmcgbmFtZXNwYWNlIF9fZ251X3BiZHM7CiAKI2RlZmluZSBmaSBmaXJzdAojZGVmaW5lIHNlIHNlY29uZAojZGVmaW5lIG1wIG1ha2VfcGFpcgojZGVmaW5lIHBiIHB1c2hfYmFjawojZGVmaW5lIGZibyBmaW5kX2J5X29yZGVyCiNkZWZpbmUgb29rIG9yZGVyX29mX2tleQogCnR5cGVkZWYgbG9uZyBsb25nIGxsOwp0eXBlZGVmIHBhaXI8bGwsbGw+IGlpOwp0eXBlZGVmIHZlY3RvcjxpbnQ+IHZpOwp0eXBlZGVmIGxvbmcgZG91YmxlIGxkOyAKdHlwZWRlZiB0cmVlPGludCwgbnVsbF90eXBlLCBsZXNzPGludD4sIHJiX3RyZWVfdGFnLCB0cmVlX29yZGVyX3N0YXRpc3RpY3Nfbm9kZV91cGRhdGU+IHBiZHM7CnR5cGVkZWYgc2V0PGludD46Oml0ZXJhdG9yIHNpdDsKdHlwZWRlZiBtYXA8aW50LGludD46Oml0ZXJhdG9yIG1pdDsKdHlwZWRlZiB2ZWN0b3I8aW50Pjo6aXRlcmF0b3Igdml0OwogCmNvbnN0IGludCBJTkYgPSBpbnQoMWU5KTsKc3RydWN0IFNDQwp7Cgl2ZWN0b3I8dmVjdG9yPGludD4gPiB2ZWM7CglpbnQgaW5kZXg7Cgl2ZWN0b3I8aW50PiBpZHg7Cgl2ZWN0b3I8aW50PiBsb3dsaW5rOwoJdmVjdG9yPGJvb2w+IG9uc3RhY2s7CglzdGFjazxpbnQ+IHM7Cgl2ZWN0b3I8aW50PiBzY2NpZHg7CglpbnQgc2NjY250OwoJLy9sb3dlciBzY2NpZHggbWVhbnMgYXBwZWFyIGxhdGVyCgl2b2lkIGluaXQoaW50IG4pCgl7CgkJaWR4LmFzc2lnbihuLC0xKTsKCQlpbmRleCA9IDA7CgkJb25zdGFjay5hc3NpZ24obiwwKTsKCQlsb3dsaW5rLmFzc2lnbihuLElORik7CgkJd2hpbGUoIXMuZW1wdHkoKSkgcy5wb3AoKTsKCQlzY2NpZHguYXNzaWduKG4sLTEpOwoJCXNjY2NudCA9IDA7CgkJdmVjLmNsZWFyKCk7CgkJdmVjLnJlc2l6ZShuKTsKCX0KCQoJdm9pZCBhZGRlZGdlKGludCB1LCBpbnQgdikgLy91IC0+IHYKCXsKCQl2ZWNbdV0ucGIodik7Cgl9CgkKCXZvaWQgY29ubmVjdChpbnQgdSkKCXsKCQlpZHhbdV0gPSBpbmRleDsKCQlsb3dsaW5rW3VdID0gaW5kZXg7CgkJaW5kZXgrKzsKCQlzLnB1c2godSk7CgkJb25zdGFja1t1XSA9IHRydWU7CgkJZm9yKGludCBpID0gMDsgaSA8IHZlY1t1XS5zaXplKCk7IGkrKykKCQl7CgkJCWludCB2ID0gdmVjW3VdW2ldOwoJCQlpZihpZHhbdl0gPT0gLTEpCgkJCXsKCQkJCWNvbm5lY3Qodik7CgkJCQlsb3dsaW5rW3VdID0gbWluKGxvd2xpbmtbdV0sIGxvd2xpbmtbdl0pOwoJCQl9CgkJCWVsc2UgaWYob25zdGFja1t2XSkKCQkJewoJCQkJbG93bGlua1t1XSA9IG1pbihsb3dsaW5rW3VdLCBpZHhbdl0pOwoJCQl9CgkJfQoJCWlmKGxvd2xpbmtbdV0gPT0gaWR4W3VdKQoJCXsKCQkJd2hpbGUoMSkKCQkJewoJCQkJaW50IHYgPSBzLnRvcCgpOwoJCQkJcy5wb3AoKTsKCQkJCW9uc3RhY2tbdl0gPSBmYWxzZTsKCQkJCXNjY2lkeFt2XSA9IHNjY2NudDsKCQkJCWlmKHYgPT0gdSkgYnJlYWs7CgkJCX0KCQkJc2NjY250Kys7CgkJfQoJfQoJCgl2b2lkIHRhcmphbigpCgl7CgkJZm9yKGludCBpID0gMDsgaSA8IHZlYy5zaXplKCk7IGkrKykKCQl7CgkJCWlmKGlkeFtpXSA9PSAtMSkKCQkJewoJCQkJY29ubmVjdChpKTsKCQkJfQoJCX0KCX0KfTsKIApTQ0Mgc2NjOwogCmNvbnN0IGludCBOID0gMzAwMDAwOwpsbCBjbnRbMzAwMDAxXTsKbGwgZHBbMzAwMDAxXTsKdmkgYWRqWzMwMDAwMV07CnZlY3RvcjxpaT4gZWRnZXM7CmludCBtYWluKCkKewoJaW9zX2Jhc2U6OnN5bmNfd2l0aF9zdGRpbygwKTsgY2luLnRpZSgwKTsKCWludCBuLCBtOyBjaW4+Pm4+Pm07CglzY2MuaW5pdChuKTsKCWZvcihpbnQgaSA9IDA7IGkgPCBuOyBpKyspCgl7CgkJY2luPj5jbnRbaV07Cgl9Cglmb3IoaW50IGkgPSAwOyBpIDwgbTsgaSsrKQoJewoJCWludCB1LCB2OwoJCWNpbj4+dT4+djsKCQl1LS07IHYtLTsKCQllZGdlcy5wYihtcCh1LHYpKTsKCQlzY2MuYWRkZWRnZSh1LHYpOwoJfQkKCXNjYy50YXJqYW4oKTsKCWludCBtYXhpZHggPSAwOwoJZm9yKGludCBpID0gMDsgaSA8IG47IGkrKykKCXsKCQlkcFtzY2Muc2NjaWR4W2ldXSArPSBjbnRbaV07CgkJbWF4aWR4ID0gbWF4KG1heGlkeCwgc2NjLnNjY2lkeFtpXSk7Cgl9Cglmb3IoaW50IGkgPSAwOyBpIDwgbTsgaSsrKQoJewoJCWludCBsID0gc2NjLnNjY2lkeFtlZGdlc1tpXS5maV07CgkJaW50IHIgPSBzY2Muc2NjaWR4W2VkZ2VzW2ldLnNlXTsKCQlpZihsPT1yKSBjb250aW51ZTsKCQlhZGpbbF0ucGIocik7CgkJYXNzZXJ0KGw+cik7Cgl9CgkvL2xhcmdlciBzY2NpZHggLT4gbG93ZXIgc2NjaWR4Cglmb3IoaW50IGkgPSAwOyBpIDw9IG1heGlkeDsgaSsrKQoJewoJCWxsIGNudCA9IGRwW2ldOwoJCWZvcihpbnQgaiA9IDA7IGogPCBhZGpbaV0uc2l6ZSgpOyBqKyspCgkJewoJCQlpbnQgdSA9IGFkaltpXVtqXTsKCQkJZHBbaV0gPSBtYXgoY250K2RwW3VdLCBkcFtpXSk7CgkJfQoJfQoJZm9yKGludCBpID0gMDsgaSA8IG47IGkrKykKCXsKCQljb3V0IDw8IGRwW3NjYy5zY2NpZHhbaV1dIDw8ICcgJzsKCX0KfQog