Pagini recente » Cod sursa (job #3246477) | Cod sursa (job #1112690) | Cod sursa (job #1817971) | Cod sursa (job #3134263) | Cod sursa (job #878677)
Cod sursa(job #878677)
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("flip.in");
ofstream g("flip.out");
int x[40],n,m,a[20][20],i,j,smax,b[20][20];
void copy()
{
for(i=1;i<=n;i++)
for(j=1;j<=m;j++)
b[i][j]=a[i][j];
}
void comp()
{int s=0;
copy();
for(i=1;i<=n;i++)
if(x[i])
for(j=1;j<=m;j++)
b[i][j]=-b[i][j];
for(i=n+1;i<=n+m;i++)
if(x[i])
for(j=1;j<=n;j++)
b[j][i-n]=-b[j][i-n];
for(i=1;i<=n;i++)
for(j=1;j<=m;j++)
s=s+b[i][j];
if (s>smax)smax=s;
}
void bt(int k)
{
for(int i=0;i<=1;i++)
{x[k]=i;
if(k==n+m)
comp();
else bt(k+1);
}
}
int main()
{f>>n>>m;
for(i=1;i<=n;i++)
for(j=1;j<=m;j++)
f>>a[i][j];
bt(1);
g<<smax;
g.close();
return 0;
}