#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; typedef long long int llint; typedef long double lldo; #define mp make_pair #define mt make_tuple #define pub push_back #define puf push_front #define pob pop_back #define pof pop_front #define fir first #define sec second #define res resize #define ins insert #define era erase /* cout<void mineq(T& a,U b){if(a>b){a=b;}} template void maxeq(T& a,U b){if(a void SO(T& ve){sort(ve.begin(),ve.end());} template void REV(T& ve){reverse(ve.begin(),ve.end());} templatellint LBI(vector&ar,T in){return lower_bound(ar.begin(),ar.end(),in)-ar.begin();} templatellint UBI(vector&ar,T in){return upper_bound(ar.begin(),ar.end(),in)-ar.begin();} int main(void){ int n,i,j,k,ans=0;cin>>n; vectorgru(133);gru[1]=1; for(i=2;i<=34*3;i++){ setaaa; if(i>=2){aaa.ins(gru[i-2]);} for(j=0;j<=(i-3)/2;j++){aaa.ins(gru[j]^gru[i-3-j]);} while(aaa.count(gru[i])){gru[i]++;} } vectorS(n+1); for(i=0;i>S[i];} S[n]=mod; SO(S); int rtu=0; for(i=0;i68){rtu=68+rtu%34;}ans^=gru[rtu];rtu=0;} } cout<<(ans?"First":"Second")<