Cod sursa(job #1211051)

Utilizator zeroblitz36FMI - Roscaneanu George zeroblitz36 Data 21 iulie 2014 22:31:45
Problema Jocul Flip Scor 20
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.21 kb
#include<cstdio>
FILE *in,*out;
int n,m,i,j,v[16][16],flag,poz1,poz2,s,min1,min2,smax=0;

void backtrack()
{
    int s=0,i,j,lsum;
    int z_flag;
    for(i=0;i<n;i++)
        for(j=0;j<m;j++)
            s+=v[i][j];

    if(s>smax)smax=s;
    //linii
    for(i=0;i<n;i++)
    {
        lsum=0;
        z_flag=0;
        for(j=0;j<m;j++)
        {
            v[i][j]*=-1;
            lsum+=v[i][j];
            if(v[i][j]==0)z_flag++;
        }
        if(z_flag!=m)
        {
            if(lsum>0)backtrack();
            for(j=0;j<m;j++)v[i][j]*=-1;
        }
    }
    //coloane
    for(j=0;j<n;j++)
    {
        lsum=0;
        z_flag=0;
        for(i=0;i<n;i++)
        {
            v[i][j]*=-1;
            lsum+=v[i][j];
            if(v[i][j]==0)z_flag++;
        }
        if(z_flag!=n)
        {
            if(lsum>0)backtrack();
            for(i=0;i<n;i++)v[i][j]*=-1;
        }
    }
}
int main()
{
    in=fopen("flip.in","r");
    fscanf(in,"%d %d",&n,&m);
    for(i=0;i<n;i++)
        for(j=0;j<m;j++)
            fscanf(in,"%d",&v[i][j]);
    fclose(in);

    backtrack();

    out=fopen("flip.out","w");
    fprintf(out,"%d",smax);
    fclose(out);
}