牛客:矩阵消除游戏

思路:由于规模在15左右,所以我们可以选择枚举(二进制枚举法(1<<n)-1).
先选行再选列,例如:如果k=5,表示我们可以选择行列一共5次,我们可以枚举0到5行的所有选择方案,假如我们选择了3行,那么我们就把在剩下的列里面选择两个最大的,每选完5次就和之前的做比较,最后取最大的一次即可。

代码核心思路

  1. 二进制枚举所有可能的选行方案 :用二进制数表示选中的行(例如 101 表示选中第 1 行和第 3 行)。

  2. 计算选行后的剩余可选列数 :若选了 num 行,则还能选 k - num 列(需保证非负)。

  3. 贪心选择最优列 :对未被选中的行,计算每列的元素和,选择最大的 k - num 列,累加其和。

  4. 记录最大值:遍历所有选行方案,保留总和最大的结果。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std; 
int n,m,k;
int num=0;
int arr[16][16]={0};
int lie[16]={0};
long long scale(int st){
    long long sum=0;
    for(int i=1;i<=n;i++){
        if(((st>>(i-1))&1)==1){
            for(int j=1;j<=m;j++){
                sum+=arr[i][j];
            }
            num++;
        }else{
            for(int j=1;j<=m;j++){
                lie[j]+=arr[i][j];
            }
        }
    }
    return sum;
}

int main(){
   
    cin>>n>>m>>k;
    int sum=0;
    for(int i=1;i<=n;i++){
        for(int j=1;j<=m;j++){
            cin>>arr[i][j];
            sum+=arr[i][j];
        }
    }
    if(k>=n||k>=m){
        cout<<sum;
        return 0;
    }
    long long ans=0;
    for(int i=0;i<=(1<<n)-1;i++){
        
        memset(lie,0,sizeof(lie));
        num=0;
        long long sum1=scale(i);
        
        if(num>k||num<0){
            continue;
        }else{
            sort(lie+1,lie+m+1);
            int x=k-num;
            for(int i=1,j=m;i<=x;i++,j--){
                sum1+=lie[j];
            }
            ans=max(ans,sum1);
        }
    }
    cout<<ans;    
    return 0;
}
相关推荐
风酥糖6 小时前
Godot游戏练习01-第24节-多人游戏暂停菜单,游戏优化
游戏·游戏引擎·godot
CDN3606 小时前
游戏盾 SDK 混淆后失效?豁免规则与打包配置解决方案
运维·游戏·网络安全
huwuhang7 小时前
Winkawaks街机游戏模拟器整合ROM版 1.65 汉化修正完整版 2026.03.30
android·游戏·游戏机
智算菩萨8 小时前
【Pygame】第20章 从0到1构建贪吃蛇:基于Pygame的游戏架构与状态机设计实战(有超详细中文注释)
python·游戏·pygame
wanhengidc10 小时前
云手机 性能不受限 数据安全
服务器·网络·安全·游戏·智能手机
ZJH__GO11 小时前
java--飞机大战游戏
java·游戏
智算菩萨11 小时前
【Pygame】第23章 平台跳跃游戏:基于有限状态机的2D平台物理模拟与摄像机视口管理系统(有超详细中文注释供大家学习)
python·游戏·pygame
CCIE-Yasuo11 小时前
《永恒战士2-无双战神》无限金币版(提供apk下载)安卓Android逆向记录学习-Deepseek-AI辅助
android·java·学习·游戏
代码小书生12 小时前
Windows X-Lite Win11 26H1 v3 游戏优化系统!集Win11、Win10、Win7三代优点,兼顾游戏办公生产算力,系统精简纯净
windows·游戏·windows x-lite·windows 游戏版·windows优化版·老电脑系统
竹之却12 小时前
【Minecraft】无法连接至服务器,登录失败:无效会话(请尝试重启游戏及启动器)
运维·服务器·游戏·我的世界·minecraft