Cod sursa(job #2043069)

Utilizator aturcsaTurcsa Alexandru aturcsa Data 19 octombrie 2017 16:55:02
Problema Jocul Flip Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.07 kb
#include <fstream>

using namespace std;
ifstream fi("flip.in");
ofstream fo("flip.out");
int N,M,rez;
int A[20][20],B[20][20];
int S[20],SC[20];
void g(int k)
{
    int i,suma;
    if (k==N)
    {
        for (int i=1;i<=N;i++)
            for (int j=1;j<=M;j++)
                if (S[i]==0)
                    B[i][j]=A[i][j];
                else
                    B[i][j]=-A[i][j];
        for (int i=1;i<=M;i++)
            SC[i]=0;
        for (int i=1;i<=N;i++)
            for (int j=1;j<=M;j++)
                SC[j]+=B[i][j];
        suma=0;
        for (int i=1;i<=M;i++)
            if (SC[i]>=0)
                suma=suma+SC[i];
            else
                suma=suma-SC[i];
        if (suma>rez)
            rez=suma;
    }
    else
        for (i=0;i<=1;i++)
        {
            S[k+1]=i;
            g(k+1);
        }
}
int main()
{
    fi>>N>>M;
    for (int i=1;i<=N;i++)
        for (int j=1;j<=M;j++)
            fi>>A[i][j];
    rez=-1;
    g(0);
    fo<<rez;
    fi.close();
    fo.close();
    return 0;
}