Cod sursa(job #2753244)

Utilizator toma_ariciuAriciu Toma toma_ariciu Data 21 mai 2021 22:54:05
Problema Jocul Flip Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.96 kb
#include <iostream>
#include <fstream>
#include <math.h>
using namespace std;
ifstream fin("flip.in");
ofstream fout("flip.out");
int N,M,i,j,k,xs[16],mat[16][16],sc[16],smax;
void prel_sol()
{
    int i,j,s=0,saux=0;
    for (i=0; i<N; i++)
    {
        saux=0;
        for (j=0; j<M; j++)
            if (xs[j])
                saux+=mat[i][j]*-1;
            else
                saux+=mat[i][j];
        s+=abs(saux);
    }
    if (s>smax)
    {
        smax=s;
        for (i=0; i<M; i++)
            sc[i]=xs[i];
    }
}
void back(int k)
{
    if (k==M)
        prel_sol();
    else
        for (int i=0; i<2; i++)
        {
            xs[k]=i;
            back(k+1);
        }
}
int main()
{
    fin>>N>>M;
    for (i=0; i<N; i++)
        for (j=0; j<M; j++)
            fin>>mat[i][j];
    back(0);
    for (j=0; j<M; j++)
        if (sc[j])
            for (i=0; i<N; i++)
                mat[i][j]*=-1;
    fout<<smax;
}