Pagini recente » Borderou de evaluare (job #3285405) | Cod sursa (job #3274120) | Cod sursa (job #2256662) | Clasamentul arhivei de probleme | Cod sursa (job #2762434)
#include<fstream>
using namespace std;
ifstream fin("flip.in");
ofstream fout("flip.out");
int n,m,a[17][17],b[17][17];
int sumMax;
int x[257];
void Copiere()
{
int i,j;
for(i=1;i<=n;i++)
for(j=1;j<=m;j++)
b[i][j]=a[i][j];
}
void Flip()
{
int i,j;
for(i=1;i<=n;i++)
if(x[i]==-1)
for(j=1;j<=m;j++)
b[i][j]=b[i][j]*(-1);
for(j=1;j<=m;j++)
if(x[j+n]==-1)
for(i=1;i<=n;i++)
b[i][j]=b[i][j]*(-1);
}
void CalcSuma()
{
Flip();
int i,j,sum=0;
for(i=1;i<=n;i++)
for(j=1;j<=m;j++)
sum=sum+b[i][j];
if(sum>sumMax)
sumMax=sum;
Copiere();
}
void Backtracking(int k)
{
if(k>n+m)
CalcSuma();
else
{
int i;
for(i=1;i<=2;i++)
{
if(i==1)
x[k]=1;
else
x[k]=-1;
Backtracking(k+1);
}
}
}
int main()
{
int i,j;
fin>>n>>m;
for(i=1;i<=n;i++)
for(j=1;j<=m;j++)
fin>>a[i][j];
Copiere();
Backtracking(1);
fout<<sumMax;
fin.close();
fout.close();
return 0;
}