Pagini recente » Cod sursa (job #2987858) | Cod sursa (job #3203100) | Cod sursa (job #2422824) | Cod sursa (job #3290830) | Cod sursa (job #2910529)
#include <bits/stdc++.h>
using namespace std;
bool flipl[20];
long long a[20][20], c, l, maxi = INT_MIN;
void backt(int m)
{
if(m==l+1)
{
int s = 0;
for(int j = 1; j<=c; j++)
{
int s1 = 0, s2 = 0;
for(int i = 1; i<=l; i++)
{
s1+=a[i][j]*(flipl[i]*2-1);
s2-=a[i][j]*(flipl[i]*2-1);
}
s+=max(s1,s2);
}
if(s>maxi)
maxi = s;
}
else
for(int i = 0; i<=1; i++)
{
flipl[m] = i;
backt(m+1);
}
}
int main()
{
ifstream f("flip.in");
ofstream g("flip.out");
f>>l>>c;
for(int i = 1; i<=l; i++)
for(int j = 1; j<=c; j++)
f>>a[i][j];
backt(1);
g<<maxi;
f.close();
g.close();
return 0;
}