#include <bits/stdc++.h>
using namespace std;
// #define int long long
using ll = long long;
using ld = long double;
#define el '\n'
#define dbg(x) cout << #x << " = " << x << el
const int N=1e5+10;
const ll INF=2e18;
vector<ll> adj[N], cores(N), vis(N), peso(N), dist(N, INF);
void solve() {
int n, m, k; cin >> n >> m >> k;
for(int i = 1; i<= n; i++){
int a; cin >>a; peso[i]=a;
}
for(int i =0; i<m; i++){
int a, b; cin >>a >> b;
adj[a].push_back(b);
adj[b].push_back(a);
}
priority_queue<pair<ll, int>, vector<pair<ll, int>>, greater<>> pq;
pq.push(make_pair(peso[1], 1));
while (!pq.empty())
{
auto [p, v] = pq.top();
pq.pop();
if(vis[v]) continue;
vis[v]=1;
for(auto x: adj[v]){
if(vis[x] || dist[x] < peso[x] + p) continue;
dist[x] = peso[x]+p;
pq.push({peso[x]+p, x});
}
}
set <int> st;
for(int i = 1; i<= n; i++) st.insert(i);
int flag = 0, comp= n-k;
for(auto x:adj[1]) if(x == n) flag = 1;
if(flag && dist[n] == peso[1] + peso[n] && k == 1 && comp == 1){
cout << "impossible\n";
return;
} else if(flag && dist[n] == peso[1] + peso[n]){
if(k > 1){
cores[1] = cores[n] = 1;k-=2;
st.erase(1); st.erase(n);
} else{
cores[1] = cores[n] = 2;
st.erase(1); st.erase(n);
}
}
// cout << dist[n]<<"\n";
if(k >= 1){
if(st.find(1) != st.end()){
k--;
cores[1] = 1;
st.erase(1);
}
for(auto x: adj[1]){
if(!k) break;
cores[x] = 1;
k--;
st.erase(x);
}
}
if(k >= 1){
if(st.find(n) != st.end()){
k--;
cores[n] =1;
st.erase(n);
}
for(auto x: adj[n]){
if(!st.size() || st.find(x) == st.end()) continue;
if(!k) break;
k--;
st.erase(x);
}
}
for(auto x: st) cores[x] = 2;
for(int i = 1; i<= n; i++){
if(cores[i] == 2) cout << "S";
else cout <<"N";
}
cout <<"\n";
}
int32_t main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int ttt = 1;
// cin >> ttt;
while(ttt--) {
solve();
}
return 0;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CgovLyAjZGVmaW5lIGludCBsb25nIGxvbmcKdXNpbmcgbGwgPSBsb25nIGxvbmc7CnVzaW5nIGxkID0gbG9uZyBkb3VibGU7CiNkZWZpbmUgZWwgJ1xuJwojZGVmaW5lIGRiZyh4KSBjb3V0IDw8ICN4IDw8ICIgPSAiIDw8IHggPDwgZWwKCmNvbnN0IGludCBOPTFlNSsxMDsKY29uc3QgbGwgSU5GPTJlMTg7CnZlY3RvcjxsbD4gYWRqW05dLCBjb3JlcyhOKSwgdmlzKE4pLCBwZXNvKE4pLCBkaXN0KE4sIElORik7Cgp2b2lkIHNvbHZlKCkgewogICAgaW50IG4sIG0sIGs7IGNpbiA+PiBuID4+IG0gPj4gazsKICAgIGZvcihpbnQgaSA9IDE7IGk8PSBuOyBpKyspewogICAgICAgIGludCBhOyBjaW4gPj5hOyBwZXNvW2ldPWE7CiAgICB9CiAgICBmb3IoaW50IGkgPTA7IGk8bTsgaSsrKXsKICAgICAgICBpbnQgYSwgYjsgY2luID4+YSA+PiBiOwogICAgICAgIGFkalthXS5wdXNoX2JhY2soYik7CiAgICAgICAgYWRqW2JdLnB1c2hfYmFjayhhKTsKICAgIH0KCiAgICBwcmlvcml0eV9xdWV1ZTxwYWlyPGxsLCBpbnQ+LCB2ZWN0b3I8cGFpcjxsbCwgaW50Pj4sIGdyZWF0ZXI8Pj4gcHE7CgogICAgcHEucHVzaChtYWtlX3BhaXIocGVzb1sxXSwgMSkpOwogICAgd2hpbGUgKCFwcS5lbXB0eSgpKQogICAgewogICAgICAgIGF1dG8gW3AsIHZdID0gcHEudG9wKCk7CiAgICAgICAgcHEucG9wKCk7CiAgICAgICAgaWYodmlzW3ZdKSBjb250aW51ZTsKICAgICAgICB2aXNbdl09MTsKCiAgICAgICAgZm9yKGF1dG8geDogYWRqW3ZdKXsKICAgICAgICAgICAgaWYodmlzW3hdIHx8IGRpc3RbeF0gPCBwZXNvW3hdICsgcCkgY29udGludWU7CiAgICAgICAgICAgIGRpc3RbeF0gPSBwZXNvW3hdK3A7CiAgICAgICAgICAgIHBxLnB1c2goe3Blc29beF0rcCwgeH0pOwogICAgICAgIH0KICAgIH0KCiAgICBzZXQgPGludD4gc3Q7CiAgICBmb3IoaW50IGkgPSAxOyBpPD0gbjsgaSsrKSBzdC5pbnNlcnQoaSk7CiAgICBpbnQgZmxhZyA9IDAsIGNvbXA9IG4tazsKICAgIGZvcihhdXRvIHg6YWRqWzFdKSBpZih4ID09IG4pIGZsYWcgPSAxOwoKICAgIGlmKGZsYWcgJiYgZGlzdFtuXSA9PSBwZXNvWzFdICsgcGVzb1tuXSAmJiBrID09IDEgJiYgY29tcCA9PSAxKXsKICAgICAgICBjb3V0IDw8ICJpbXBvc3NpYmxlXG4iOwogICAgICAgIHJldHVybjsKICAgIH0gZWxzZSBpZihmbGFnICYmIGRpc3Rbbl0gPT0gcGVzb1sxXSArIHBlc29bbl0pewogICAgICAgIGlmKGsgPiAxKXsKICAgICAgICAgICAgY29yZXNbMV0gPSBjb3Jlc1tuXSA9IDE7ay09MjsKICAgICAgICAgICAgc3QuZXJhc2UoMSk7IHN0LmVyYXNlKG4pOwogICAgICAgIH0gZWxzZXsKICAgICAgICAgICAgY29yZXNbMV0gPSBjb3Jlc1tuXSA9IDI7CiAgICAgICAgICAgIHN0LmVyYXNlKDEpOyBzdC5lcmFzZShuKTsKICAgICAgICB9CiAgICB9CiAgICAKICAgIC8vIGNvdXQgPDwgZGlzdFtuXTw8IlxuIjsKICAgIAogICAgCiAgICBpZihrID49IDEpewogICAgICAgIGlmKHN0LmZpbmQoMSkgIT0gc3QuZW5kKCkpewogICAgICAgICAgICBrLS07CiAgICAgICAgICAgIGNvcmVzWzFdID0gMTsKICAgICAgICAgICAgc3QuZXJhc2UoMSk7CiAgICAgICAgfQoKICAgICAgICBmb3IoYXV0byB4OiBhZGpbMV0pewogICAgICAgICAgICBpZighaykgYnJlYWs7CiAgICAgICAgICAgIGNvcmVzW3hdID0gMTsKICAgICAgICAgICAgay0tOwogICAgICAgICAgICBzdC5lcmFzZSh4KTsKICAgICAgICB9CiAgICB9CgogICAgaWYoayA+PSAxKXsKICAgICAgICBpZihzdC5maW5kKG4pICE9IHN0LmVuZCgpKXsKICAgICAgICAgICAgay0tOwogICAgICAgICAgICBjb3Jlc1tuXSA9MTsKICAgICAgICAgICAgc3QuZXJhc2Uobik7CiAgICAgICAgfQogICAgICAgIAogICAgICAgIGZvcihhdXRvIHg6IGFkaltuXSl7CiAgICAgICAgICAgIGlmKCFzdC5zaXplKCkgfHwgc3QuZmluZCh4KSA9PSBzdC5lbmQoKSkgY29udGludWU7CiAgICAgICAgICAgIGlmKCFrKSBicmVhazsKICAgICAgICAgICAgay0tOwogICAgICAgICAgICBzdC5lcmFzZSh4KTsKICAgICAgICB9CiAgICB9CgogICAgZm9yKGF1dG8geDogc3QpIGNvcmVzW3hdID0gMjsKICAgIGZvcihpbnQgaSA9IDE7IGk8PSBuOyBpKyspewogICAgICAgIGlmKGNvcmVzW2ldID09IDIpIGNvdXQgPDwgIlMiOwogICAgICAgIGVsc2UgY291dCA8PCJOIjsKICAgIH0KICAgIGNvdXQgPDwiXG4iOwoKCn0KCmludDMyX3QgbWFpbigpIHsKICAgIGlvczo6c3luY193aXRoX3N0ZGlvKGZhbHNlKTsKICAgIGNpbi50aWUobnVsbHB0cik7CgogICAgaW50IHR0dCA9IDE7CiAgICAvLyBjaW4gPj4gdHR0OwogICAgd2hpbGUodHR0LS0pIHsKICAgICAgICBzb2x2ZSgpOwogICAgfQogICAgcmV0dXJuIDA7Cn0=