Pagini recente » Cod sursa (job #1665267) | Cod sursa (job #1782283) | Cod sursa (job #2269788) | Cod sursa (job #1561076) | Cod sursa (job #2753244)
#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;
}