Pagini recente » Cod sursa (job #1369674) | Cod sursa (job #1939330) | Cod sursa (job #1963827) | Cod sursa (job #299592) | Cod sursa (job #2278695)
#include <iostream>
#include <cstdio>
#include <vector>
using namespace std;
long long calcSum(vector<vector<int>> x) {
long long sum = 0;
int length = x.size(), length2;
for(int i = 0; i < length; ++i) {
length2 = x[i].size();
for(int j = 0; j < length2; ++j)
sum += x[i][j];
}
return sum;
}
void reverseLine(vector<vector<int>> &x, int line) {
int length = x[line].size();
for(int j = 0; j < x[line].size(); ++j)
x[line][j] *= -1;
}
void reverseCol(vector<vector<int>> &x, int col) {
int length = x.size();
for(int i = 0; i < x.size(); ++i)
x[i][col] *= -1;
}
int main()
{
freopen("flip.in", "r", stdin);
freopen("flip.out", "w", stdout);
int n, m;
cin >> n >> m;
vector<vector<int>> x(n, vector<int>(m));
for (int i = 0; i < n; ++i) {
for(int j = 0; j < m; ++j)
cin >> x[i][j];
}
for(int k = 0; k < n * m; ++k) {
for(int i = 0; i < n; ++i) {
int sum = 0;
for(int j = 0; j < m; ++j)
sum += x[i][j];
if (sum < 0)
reverseLine(x, i);
}
for(int j = 0; j < m; ++j) {
int sum = 0;
for(int i = 0; i < n; ++i)
sum += x[i][j];
if(sum < 0)
reverseCol(x, j);
}
}
cout << calcSum(x);
return 0;
}