Cod sursa(job #3197144)

Utilizator Antonio_BiscoveanuAntonio Biscoveanu Antonio_Biscoveanu Data 25 ianuarie 2024 19:43:08
Problema Perle Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.71 kb
#include <bits/stdc++.h>

using namespace std;
ifstream fin("perle.in");
ofstream fout("perle.out");

int t,n,i,v[10005];
int A();
int B();
int C();

int A()
{
    if(i==n+1)
        return 0;
    if(v[i]==1 || v[i]==2 || v[i]==3)
    {
        i++;
        return 1;
    }
    else
        return 0;
}
int B()
{
    if(i==n+1)
        return 0;
    if(v[i]==2)
    {
        i++;
        return B();
    }
    else if(v[i]==1)
    {
        i++;
        int aux=A();
        if(aux==0)
            return 0;
        if(v[i]!=3)
            return 0;
        i++;
        aux=A();
        if(aux==0)
            return 0;
        return C();
    }
    else
        return 0;
}
int C()
{
    if(i==n+1)
        return 0;
    if(v[i]==2)
    {
        i++;
        return 1;
    }
    else if(v[i]==1)
    {
        i++;
        if(v[i]!=2)
        {
            i++;
            return 0;
        }
        else
        {
            i++;
            return A();
        }
    }
    else
    {
        i++;
        int aux=B();
        if(aux==0)
            return 0;
        return C();
    }
}
int main()
{
    fin>>t;
    while(t--)
    {
        fin>>n;
        for(int j=1; j<=n; j++)
            fin>>v[j];
        i=1;
        int r=A();
        if(r==1 && i==n+1)
        {
            fout<<1<<'\n';
            continue;
        }
        i=1;
        r=B();
        if(r==1 && i==n+1)
        {
            fout<<1<<'\n';
            continue;
        }
        i=1;
        r=C();
        if(r==1 && i==n+1)
        {
            fout<<1<<'\n';
            continue;
        }
        fout<<0<<'\n';
    }
    return 0;
}