#include using namespace std; #define rep(i, x, limit) for (long long i = (long long)x; i < (long long)limit; i++) #define REP(i, x, limit) for (long long i = (long long)x; i <= (long long)limit; i++) #define all(x) x.begin(), x.end() #define rall(x) x.rbegin(), x.rend() #define el endl #define spa " " #define Yes cout << "Yes" << el #define No cout << "No" << el #define YES cout << "YES" << el #define NO cout << "NO" << el #define eps (1e-10) #define Equals(a,b) (fabs((a) - (b)) < eps ) #define debug(x) cerr << #x << " = " << x << el using ll = long long; using ull = unsigned long long; using pii = pair; using pll = pair; using vi = vector; using vl = vector; using vvl = vector>; using vs = vector; using vb = vector; const double pi = 3.141592653589793238; const int inf = 1073741823; const ll infl = 1LL << 60; const string ABC = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"; const string abc = "abcdefghijklmnopqrstuvwxyz"; const ll MOD = 998244353; #include using namespace atcoder; using mint = modint998244353; using vm = vector; template void print_sp(const T& a){ bool first = true; for (auto&& x : a){ if (!first) cout << ' '; first = false; cout << x; } cout << '\n'; } int main() { ios::sync_with_stdio(false); cin.tie(nullptr); string s;cin>>s; vvl D(26,vl(26));rep(i,0,26)rep(j,0,26)cin>>D[i][j]; vvl Al(26); rep(i,0,s.size()){ ll al=s[i]-'a'; Al[al].push_back(i); } vector> ans(26,vector(26,'N')); rep(i,0,26){ auto &A = Al[i]; rep(j,0,26){ auto &B = Al[j]; bool ok = true; for(auto &a : A){ auto it = upper_bound(all(B), a); if(it == B.end()) continue; if(a + D[i][j] > *it){ ok = false; break; } } ans[i][j] = ok ? 'Y' : 'N'; } } for(auto I:ans){ print_sp(I); } }