Pagini recente » Cod sursa (job #10459) | Cod sursa (job #3135500) | Cod sursa (job #684732) | Cod sursa (job #869113) | Cod sursa (job #2727252)
#include <iostream>
#include<fstream>
#include <math.h>
using namespace std;
ifstream f ("flip.in");
ofstream g ("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()
{
f>>N>>M;
for (i=0; i<N; i++)
for (j=0; j<M; j++)
f>>mat[i][j];
back(0);
for (j=0; j<M; j++)
if (sc[j])
for (i=0; i<N; i++)
mat[i][j]*=-1;
g<<smax;
}