#include <iostream>
#include <algorithm>
#include <cstring>
#include <cstdio>
#include <cmath>
#include <queue>
#include <stack>
#include <map>
#include <vector>
#include <set>
typedef long long ll;
using namespace std;
const int maxn=1e5+10;
const int inf=0x3f3f3f3f;
int t,n,a[55][55],dis[55],sum[55][55];
char c;
bool vis[55];
void work(int x)
{
for(int i=1;i<=n;i++)
if(a[x][i]&&!vis[i]&&dis[i]>dis[x]+sum[x][i-1])
dis[i]=dis[x]+sum[x][i-1];
}
int main()
{
scanf("%d",&t);
while(t--)
{
memset(a,0,sizeof(a));
memset(sum,0,sizeof(sum));
memset(vis,false,sizeof(vis));
scanf("%d",&n);
for(int i=1;i<=n;i++)
dis[i]=inf;
for(int i=1;i<=n;i++)
{
getchar();
for(int j=1;j<=n;j++)
{
scanf("%c",&c);
if(c=='Y')
{
sum[i][j]=sum[i][j-1]+1;
a[i][j]=1;
}
else
{
a[i][j]=0;
sum[i][j]=sum[i][j-1];
}
}
}
for(int i=2;i<=n;i++)
if(a[1][i]) dis[i]=sum[1][i-1];
vis[1]=true;
for(int i=2;i<=n;i++)
{
int key;int minn=inf;
for(int j=1;j<=n;j++)
{
if(dis[j]<minn&&!vis[j])
{
minn=dis[j];
key=j;
}
}
vis[key]=true;
work(key);
}
if(dis[n]<inf) printf("%d\n",dis[n]);
else printf("-1\n");
}
return 0;
}