题意:
data:image/s3,"s3://crabby-images/d9099/d90995707d588a5b53228e69d8629a51a8390307" alt=""
data:image/s3,"s3://crabby-images/cd6cd/cd6cd16264cbc3c730ac2dc07b6a061f28600cf6" alt=""
思路:
data:image/s3,"s3://crabby-images/7096e/7096edcf868318f5a5eff3b6ec946936b2ee0a01" alt=""
data:image/s3,"s3://crabby-images/d836e/d836ece524842c7ef468d1b04cffc85f48045575" alt=""
data:image/s3,"s3://crabby-images/79fb6/79fb671286b862044d195c52f91d23a37597e184" alt=""
#include <cstdio>
#include <algorithm>
using namespace std;
const int N = 18;
int n,m,k;
int a[N][N];
int main(){
scanf("%d%d%d",&n,&m,&k);
int sum = 0;
for(int i = 0;i < n;i++){
for(int j = 0;j < m;j++){
scanf("%d",&a[i][j]);
sum += a[i][j];
}
}
if(k >= min(n,m)) {printf("%d\n",sum);return 0;}
//枚举行
int mx = 0;
for(int s = 0;s < (1<<n);s++){
int cnt = __builtin_popcount(s);
if(cnt > k || k - cnt > m) continue;
int res = 0;
for(int i = 0;i < n;i++){
if((s >> i)&1){
for(int j = 0;j < m;j++){
res += a[i][j];
}
}
}
vector<int> v;//贪心列
for(int j = 0;j < m;j++){
int ret = 0;
for(int i = 0;i < n;i++){
if(!((s>>i)&1)){
ret += a[i][j];
}
}
v.push_back(ret);
}
sort(v.begin(),v.end(),greater<int>());
for(int i = 0;i < k - cnt && i < m;i++){
res += v[i];
}
mx = max(res,mx);
}
printf("%d\n",mx);
return 0;
}