当前位置: 首页 > news >正文

蓝桥杯备考---》贪心算法之矩阵消除游戏

我们第一次想到的贪心策略一定是找出和最大的行或者列来删除,每次都更新行和列

比如如图这种情况,这种情况就不如直接删除两行的多,所以本贪心策略有误

so我们可以枚举选的行的情况,然后再贪心的选择列和最大的列来做

#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
int n,m,k;
typedef long long ll;
const int N = 20;

int sum;

int col[N];
int a[N][N];


	int calc(int x)
{
 int ret = 0;
 while(x)
 {
 ret++;
 x -= x & -x; 
 }
 return ret;
}

bool cmp(int x,int y)
{
	return x>y;
}
int ret;

int main()
{
	cin >> n >> m >> k;
	for(int i = 0;i<n;i++)
	{
		for(int j = 0;j<m;j++)
		{
			cin >> a[i][j];
		}
	}
	for(int st = 0;st<(1<<n);st++)
	{
		memset(col,0,sizeof(col));
		sum = 0;
		if(calc(st)>k) continue;
		for(int i = 0;i<n;i++)
		{
			for(int j = 0;j<m;j++)
			{
				if((st>>i)&1) sum+=a[i][j];
				else col[j]+=a[i][j];
			}
		}
		sort(col,col+m,cmp);
		int tmp = k-calc(st);
		for(int i = 0;i<tmp;i++)
		{
			sum+=col[i];
		}
		ret = max(ret,sum);
		
	}
	cout << ret; 
	
	
	
	
	return 0;
}

这样写是有bug的,我们选列的时候有可能会越界

因为我们的k最高是n*m,假如不选行,全选列,列是不够选的啊,我们应该对col的遍历范围做点限制,不能超过m

正确代码√

#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
int n,m,k;
typedef long long ll;
const int N = 20;
int a[N][N];
int sum;
int col[N];




	int calc(int x)
{
 int ret = 0;
 while(x)
 {
 ret++;
 x -= x & -x; 
 }
 return ret;
}

bool cmp(int x,int y)
{
	return x>y;
}
int ret;
int main()
{
	cin >> n >> m >> k;
	for(int i = 0;i<n;i++)
	{
		for(int j = 0;j<m;j++)
		{
			cin >> a[i][j];
		}
	}
	for(int st = 0;st<(1<<n);st++)
	{
		memset(col,0,sizeof(col));
		sum = 0;
		if(calc(st)>k) continue;
		for(int i = 0;i<n;i++)
		{
			for(int j = 0;j<m;j++)
			{
				if((st>>i)&1) sum+=a[i][j];
				else col[j]+=a[i][j];
			}
		}
		sort(col,col+m,cmp);
		int tmp = k-calc(st);
		for(int i = 0;i<min(tmp,m);i++)
		{
			sum+=col[i];
		}
		ret = max(ret,sum);
		
	}
	cout << ret; 
	
	
	
	
	return 0;
}

相关文章:

  • 理解Java数据库编程之JDBC
  • 用户模块——业务校验工具AssertUtil
  • 10-SpringBoot3入门-整合TX(事务)
  • 【插件】美化html标签的class 属性上的 tailwindcss 类;Prettier-plugin-tailwindcss
  • 数据链路层协议--以太网协议
  • 结构型设计模式。持续更新
  • ToolsSet之:梯度色板
  • MySQL与Redis数据一致性保障方案详解
  • Langflow深度解析:从核心概念到开发实践
  • Vitis HLS 学习笔记--块级控制(IDE 2024.1 + 执行模式 + 默认接口实现)
  • USB——删除注册表信息
  • UE5学习笔记 FPS游戏制作33 换子弹 动画事件
  • 服务新增节点、迁移笔记
  • 【零基础入门unity游戏开发——通用篇】图片相关设置
  • 【编译、链接与构建详解】Makefile 与 CMakeLists 的作用
  • 【NLP 面经 3】
  • 基于Python的Django框架的个人博客管理系统
  • 大模型在广告行业的一些发展与应用笔记
  • 命令模式介绍及应用案例
  • 数据生成PDF定时批量发送到目标邮箱
  • 徐州有哪些网站制作公司/写文案接单平台
  • 便宜做网站的公司靠谱吗/东莞今天最新消息新闻
  • 美食门户类网站模版/国内能用的搜索引擎
  • 网站建设需要了解的信息/如何在百度发布文章
  • 电子商务网站调研报告/微信搜一搜怎么做推广
  • 做公司网站员工保险/太原seo网络优化招聘网