Cod sursa(job #1638534)

Utilizator razvanlgu31Razvan Lungu razvanlgu31 Data 7 martie 2016 23:56:41
Problema Copii Scor 80
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.99 kb
#include <fstream>
#include <cstring>

using namespace std;

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

void ver()
{
    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++;
}

void bac(int k)
{
    if (k==n+1) ver();
    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; char c;
    for (i=1; i<=n; i++)
        for (j=1; j<=n; j++)
            fin >> c, a[i][j]=c-'0';
    bac(1);
    fout<<nrsol;
}