矩阵消除游戏

题号:NC200190
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld
题目描述
牛妹在玩一个名为矩阵消除的游戏,矩阵的大小是n行m列,第i行第j列的单元格的权值为a[i][j]​ ,牛妹可以进行{k}k个回合的游戏,在每个回合,牛妹可以选择一行或者选择一列,然后将这一行或者这一列的所有单元格中的权值变为0,同时牛妹的分数会加上这一行或者这一列中的所有单元格的权值的和。

牛妹想最大化她的得分,球球你帮帮她吧!

输入描述:
第一行三个整数n,m,k
接下来n行每行m个整数表示矩阵中各个单元格的权值。
输出描述:
输出一个整数表示牛妹能获得的最大分数。
示例1
输入
3 3 2
101 1 102
1 202 1
100 8 100
输出
414

通过数据范围可以联想到状态压缩,枚举所有行的选取,在对列进行贪心即可

#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
typedef long long ll;
const int N =  25;
int n,k,m,ans;
int sumh[N],p[N][N],suml[N];
int b[N];
inline int query(int x){
	memset(b,0,sizeof b);
	int cnt=0;
	for(int i=0;i<n;i++)
    {
        b[i]=(x>>i)&1;
        if(b[i]==1)cnt++;
    }
	return cnt;
}
int main(){
    cin>>n>>m>>k;
   	if(k>=min(n,m))k=min(n,m);
    for(int i=0;i<n;i++)
    for(int j=0;j<m;j++)
    cin>>p[i][j],sumh[i]+=p[i][j];
    int s=(1<<n)-1;
    for(int i=0;i<=s;i++){
        int sum=0;
    	int cnt=query(i);
    	int cnth=cnt,cntl=k-cnt;
    	if(cntl<0||cntl>m){
            continue;
        }
    	for(int k=0;k<n;k++)
    	if(b[k])sum+=sumh[k];
    	memset(suml,0,sizeof suml);
		for(int k=0;k<n;k++)
    	for(int j=0;j<m;j++)
    	if(!b[k])suml[j]+=p[k][j];
    	sort(suml,suml+m,greater<>());
    	for(int j=0;j<cntl;j++)sum+=suml[j];
    	ans=max(ans,sum);
	}
	cout<<ans;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值