Cod sursa(job #1638553)

Utilizator razvanlgu31Razvan Lungu razvanlgu31 Data 8 martie 2016 00:07:21
Problema Copii Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.98 kb
#include <fstream>
#include <cstring>

using namespace std;

ifstream fin("copii.in");
ofstream fout("copii.out");
char c;
int n,i,j,nrsol,nc,v[15];
bool a[15][15];

void bac(int k)
{
    if (k==n+1)
    {
        bool r[15][15];
    int i,j;
    if (nc<=1) return;
    for (i=1; i<=nc; i++)
    {
        for (j=1; j<=nc; j++)
            r[i][j]=0;
        r[i][i]=1;
    }
    for (i=1; i<=n; i++)
        for (j=1; j<=n; j++)
            if (a[i][j]==1&&j!=i&&v[i]!=v[j])
                r[v[i]][v[j]]=1;
    for (i=1; i<=nc; i++)
        for (j=1; j<=nc; j++)
            if (r[i][j]==0) return;
    nrsol++;
    }
    else
    {
        for (int j=1; j<=nc; j++)
        {
            v[k]=j;
            bac(k+1);
        }
        nc++;
        v[k]=nc;
        bac(k+1);
        nc--;
    }
}

int main()
{
    fin>>n;
    for (i=1; i<=n; i++)
        for (j=1; j<=n; j++)
            fin >> c, a[i][j]=c-'0';
    bac(1);
    fout<<nrsol;
}