#include using namespace std; #define mp make_pair #define pb push_back #define x first #define y second typedef pair pii; typedef long long ll; typedef unsigned long long ull; template void chkmax(T &x,T y){x void chkmin(T &x,T y){y void readint(T &x) { x=0;int f=1;char c; for(c=getchar();!isdigit(c);c=getchar())if(c=='-')f=-1; for(;isdigit(c);c=getchar())x=x*10+(c-'0'); x*=f; } /*const int MOD=; inline int dmy(int x){return x>=MOD?x-MOD:x;} inline void inc(int &x,int y){x=dmy(x+y);} int qmi(int x,int y) { int ans=1; for(;y;y>>=1,x=1ll*x*x%MOD) if(y&1)ans=1ll*ans*x%MOD; return ans; }*/ const int MAXN=100005; int n,a[MAXN],fa[MAXN]; int getfa(int u){return u==fa[u]?u:fa[u]=getfa(fa[u]);} int calc() { for(int i=1;i<=n;++i)fa[i]=i; for(int i=1;i<=n;++i)fa[getfa(i)]=getfa(a[i]); int cnt=0; for(int i=1;i<=n;++i)cnt+=(i==getfa(i)); return cnt; } void solve() { readint(n); for(int i=1;i<=n;++i)readint(a[i]); printf(calc()<=30?"Second\n":"First\n"); } int main() { #ifdef LOCAL freopen("code.in","r",stdin); // freopen("code.out","w",stdout); #endif int T; readint(T); while(T--)solve(); return 0; }