【牛客小白月赛23 A】膜法记录 (二进制枚举)

2024-02-24 03:20

本文主要是介绍【牛客小白月赛23 A】膜法记录 (二进制枚举),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【题目传送门】

题目描述:

牛牛最近在玩一款叫做《膜法记录》的游戏,这个游戏的机制是这样的: 在一局游戏中,所有的敌人都排布在一个 n{n}n 行 m{m}m 列的网格中,牛牛指挥着他的魔法少女对敌人进行攻击。 攻击有两种类型:行blast,列blast 行blast能消灭一整行的敌人,列blast能消灭一整列的敌人 牛牛总共能够释放 a{a}a 次行blast,b{b}b 次列blast 给定某局游戏的初始局面,请问牛牛能否将敌人全歼?

输入描述:

第一行包含一个正整数T,表示测试数据组数,接下来是T组测试数据每组测试数据的第一行有四个正整数 n,m,a,b接下来有n{n}n行,每行是一个长度为m的字符串,第i行第j列的字符如果是 * 则说明这里有一个敌人,如果是 . 说明这里没有

输出描述:

对每组测试数据输出一行,如果能消灭所有的敌人,就输出yes,否则输出no

说明

第一个样例,我可以在第一行放一个行blast,然后前两列都放一个列blast,就把敌人给全歼了。第二个样例,我不管怎么安排攻击策略,都没法全歼敌人

备注:

在这里插入图片描述

分析:

这道题的n很小,只有20,我们可以利用二进制数来枚举可操作的行,我们可以认为1是对行操作,0是不操作;比如n=4时,若对3,4行操作对应的二进制数表示为1100。
由此我们对 0到2^n-1 (0表示都不操作,2^n-1表示的二进制数每一位都为1,即表示对n行都操作)范围内的数进行遍历,即枚举各种可操作行的组合
然后再对整个矩阵进行遍历,选出来没有被行操作过得敌人,让列进行操作,如果 列操作 的次数小于题目中给定的次数,即满足,反之不满足。

代码如下:

#include <bits/stdc++.h>
using namespace std;
const int N=1e6+100;
string s[N];//字符串数组
int main() {int n,m,a,b,t;int flag;cin>>t;while(t--){flag=0;cin>>n>>m>>a>>b;for(int i=0;i<n;i++) cin>>s[i];for(int i=0;i<(1<<n);i++)//枚举0-2^n-1范围内的数,即枚举各种组合;{int x=0;for(int j=0;j<n;j++)if((i>>j)&1) x++;//判断有几个位有1,即对 几行 操作if(x!=a) continue;int y=0;for(int j=0;j<m;j++)for(int k=0;k<n;k++)if(s[k][j]=='*'&&!((i>>k)&1))//判断一下这个行有没有操作过,如果行操作过,就不用列操作了{y++;break;//这一列消灭完了,就跳出这一列到下一列;}if(y<=b) flag=1;}if(flag) cout<<"yes"<<endl;else cout<<"no"<<endl;}return 0;
}

six day~

这篇关于【牛客小白月赛23 A】膜法记录 (二进制枚举)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/740802

相关文章

在Spring Boot中浅尝内存泄漏的实战记录

《在SpringBoot中浅尝内存泄漏的实战记录》本文给大家分享在SpringBoot中浅尝内存泄漏的实战记录,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录使用静态集合持有对象引用,阻止GC回收关键点:可执行代码:验证:1,运行程序(启动时添加JVM参数限制堆大小):2,访问 htt

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

Spring Boot中定时任务Cron表达式的终极指南最佳实践记录

《SpringBoot中定时任务Cron表达式的终极指南最佳实践记录》本文详细介绍了SpringBoot中定时任务的实现方法,特别是Cron表达式的使用技巧和高级用法,从基础语法到复杂场景,从快速启... 目录一、Cron表达式基础1.1 Cron表达式结构1.2 核心语法规则二、Spring Boot中定

国内环境搭建私有知识问答库踩坑记录(ollama+deepseek+ragflow)

《国内环境搭建私有知识问答库踩坑记录(ollama+deepseek+ragflow)》本文给大家利用deepseek模型搭建私有知识问答库的详细步骤和遇到的问题及解决办法,感兴趣的朋友一起看看吧... 目录1. 第1步大家在安装完ollama后,需要到系统环境变量中添加两个变量2. 第3步 “在cmd中