Pagini recente » Cod sursa (job #1849207) | Cod sursa (job #2497111) | Cod sursa (job #1934442) | Cod sursa (job #2620631) | Cod sursa (job #889496)
Cod sursa(job #889496)
#include <cstdio>
using namespace std;
int a[10002],n,i,m,j;
int Pb(int);
int Pc(int);
int Pb(int i)
{if (i<=m)
{if (a[i]==1 && a[i+2]==3) return Pc(i+4);
else if (a[i]==2) return Pb(i+1);
}
return 0;
}
int Pc(int i)
{if (i<=m)
{if (a[i]==2) return i;
else if (a[i]==3) return Pc(Pb(i+1)+1);
else if (a[i]==1 && a[i+1]==2) return i+2;
}
return 0;
}
int main()
{FILE *f1 = fopen("perle.in","r");
FILE *f2 = fopen("perle.out","w");
fscanf(f1,"%d",&n);
for (i=1;i<=n;i++)
{fscanf(f1,"%d",&m);
for (j=1;j<=m;j++) fscanf(f1,"%d",&a[j]);
if (m==1) fprintf(f2,"1\n");
else
{if (Pb(1)==m || Pc(1)==m) fprintf(f2,"1\n");
else fprintf(f2,"0\n");
}
}
fclose(f1);fclose(f2);
return 0;
}