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

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

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

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

cpp 复制代码
#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

正确代码√

cpp 复制代码
#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;
}
相关推荐
_dindong3 分钟前
笔试强训:Week -8
开发语言·c++·算法
LYFlied19 分钟前
【每日算法】LeetCode 105. 从前序与中序遍历序列构造二叉树
数据结构·算法·leetcode·面试·职场和发展
DanyHope24 分钟前
LeetCode 206. 反转链表:迭代 + 递归双解法全解析
算法·leetcode·链表·递归·迭代
NAGNIP28 分钟前
才发现TensorBoard是个可视化的神器!
算法
_dindong34 分钟前
算法杂谈:回溯路线
数据结构·算法·动态规划·bfs·宽度优先
咋吃都不胖lyh34 分钟前
详解 UCB 算法的置信区间与核心逻辑(通俗 + 公式 + 实例)
人工智能·算法·机器学习
DanyHope42 分钟前
LeetCode 两数之和:从 O (n²) 到 O (n),空间换时间的经典实践
前端·javascript·算法·leetcode·职场和发展
free-elcmacom1 小时前
机器学习高阶教程<6>推荐系统高阶修炼手册:混排、多任务与在线学习,解锁精准推荐新境界
人工智能·python·学习·算法·机器学习·机器人
断剑zou天涯1 小时前
【算法笔记】AC自动机
java·笔记·算法
IT猿手1 小时前
基于粒子群算法与动态窗口混合的无人机三维动态避障路径规划研究,MATLAB代码
算法·matlab·无人机·多目标优化算法·多目标算法