Pagini recente » Cod sursa (job #1174115) | Cod sursa (job #2901286) | Cod sursa (job #2085599) | Cod sursa (job #2828539) | Cod sursa (job #2123060)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("perle.in");
ofstream fout("perle.out");
int v[10005], n, k;
int B(int);
int C(int);
int B(int poz)
{
if(poz<=k) {
if(v[poz]==2)
return B(poz+1);
else
if(v[poz]==1 && v[poz+2]==3)
return C(poz+4);
}
return -1;
}
int C(int poz)
{
if(poz<=k) {
if(v[poz]==2)
return poz+1;
else if(v[poz]==3)
return C(B(poz+1));
else if(v[poz]==1 && v[poz+1]==2)
return poz+3;
}
return -1;
}
int main()
{
fin>>n;
while(n--) {
fin>>k;
for(int i=1; i<=k; i++)
fin>>v[i];
if(k==1)
fout<<1<<'\n';
else
fout<<(B(1)==k+1 || C(1)==k+1)<<'\n';
}
return 0;
}