Pagini recente » Cod sursa (job #1932898) | Cod sursa (job #220446) | Cod sursa (job #3001114) | Cod sursa (job #1926382) | Cod sursa (job #2628689)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("elimin.in");
ofstream fout("elimin.out");
int n, m, r, c, fr[10000], fr2[10000], maxim;
void Rotate(vector <vector <int> > &matrix)
{
vector <vector <int> > aux;
for (int j = 0; j < m; ++j)
{
vector <int> v;
for (int i = 0; i < n; ++i)
{
v.push_back(matrix[i][j]);
}
aux.push_back(v);
}
matrix = aux;
swap(n, m);
swap(r, c);
}
int main()
{
fin >> n >> m >> r >> c;
vector <vector <int> > matrix;
for (int i = 0; i < n; ++i)
{
vector <int> aux;
for (int j = 0; j < m; ++j)
{
int x;
fin >> x;
aux.push_back(x);
}
matrix.push_back(aux);
}
if (n < m) Rotate(matrix);
for (int i = 0; i < n; ++i)
{
for (int j = 0; j < m; ++j)
{
fr[i] += matrix[i][j];
}
}
int l = (1 << m);
for (int stare = 0; stare < l; ++stare)
{
if (__builtin_popcount(stare) == c)
{
for (int i = 0; i < n; ++i)
{
fr2[i] = fr[i];
}
for (int i = 0; i < m; ++i)
{
int bit = (stare >> i) & 1;
if (bit == 1)
for (int j = 0; j < n; ++j)
{
fr2[j] -= matrix[j][i];
}
}
sort(fr2, fr2 + n);
int sum = 0;
for (int i = r; i < n; ++i)
{
sum += fr2[i];
}
maxim = max(maxim, sum);
}
}
fout << maxim;
fin.close();
fout.close();
return 0;
}