HDU-5319 Painter,深搜标记!
题意:有一个棋盘n行,列数不超过50,用red和blue给这个棋盘涂色,每个格子每种颜色最多涂一次,如果两种颜色都涂了则该格子颜色为Green;red以斜杠‘\‘方式涂色,bule以’/‘方式涂色。给出涂色后的棋盘,问最少涂了几次。
思路:搜索的思路没错,不过这题有点小坑,题目只告诉了行,并没有明确列,所以得自己求出。涂色时并不是一涂到底,也可以连续几个对角的格子涂色。所以不管是暴力枚举还是搜索都行。
const int N=100+5;
char s[N][N];
int n,m;
void dfs(int x,int y,char c)
{
if(s[x][y]=='.') return ;//隔断了,不用往下涂色了
if(s[x][y]==c)
{
s[x][y]='.';
if(c=='B')
{
if(x+1<n&&y-1>=0) dfs(x+1,y-1,c);//反斜杠方向涂色
}
else
{
if(x+1<n&&y+1<m) dfs(x+1,y+1,c);
}
}
else
{
if(s[x][y]!='G') return ;
else
{
if(c=='B')
{
s[x][y]='R';//清楚标记,换另一个方向涂色
if(x+1<n&&y-1>=0) dfs(x+1,y-1,c);
}
else
{
s[x][y]='B';
if(x+1<n&&y+1<m) dfs(x+1,y+1,c);
}
}
}
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
for(int i=0; i<n; i++)
scanf("%s",s[i]);
m=strlen(s[0]);
int ans=0;
for(int i=0; i<n; i++)
for(int j=0; j<m; j++)
if(s[i][j]!='.')
{
if(s[i][j]=='G')
{
ans+=2;
dfs(i,j,'B');
dfs(i,j,'R');
}
else
{
ans++;
if(s[i][j]=='B') dfs(i,j,'B');
if(s[i][j]=='R') dfs(i,j,'R');
}
}
printf("%d\n",ans);
}
return 0;
}
HDU-5319 Painter,深搜标记!的更多相关文章
- hdu 5319 Painter(杭电多校赛第三场)
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5319 Painter Time Limit: 2000/1000 MS (Java/Others) ...
 - Block Breaker HDU - 6699(深搜,水,写下涨涨记性)
		
Problem Description Given a rectangle frame of size n×m. Initially, the frame is strewn with n×m squ ...
 - HDOJ/HDU 1015 Safecracker(深搜)
		
Problem Description === Op tech briefing, 2002/11/02 06:42 CST === "The item is locked in a Kle ...
 - hdu 1518   Square   深搜,,,,花样剪枝啊!!!
		
Square Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Su ...
 - HDU   5319  Painter(枚举)
		
Painter Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Total Su ...
 - HDU 5319 Painter (模拟)
		
题意: 一个画家画出一张,有3种颜色的笔,R.G.B.R看成'\',B看成'/',G看成这两种的重叠(即叉形).给的是一个矩阵,矩阵中只有4种符号,除了3种颜色还有'.',代表没有涂色.问最小耗费多少 ...
 - HDU 5319  Painter
		
题意:红色从左上向右下涂,蓝色从右上向左下涂,既涂红色又涂蓝色就变成绿色,问最少涂几下能变成给的图. 解法:模拟一下就好了,注意细节. 代码: #include<stdio.h> #inc ...
 - HDU 2614 Beat  深搜DFS
		
这道题目还是比较水的,但是题意理解确实费了半天劲,没办法 谁让自己是英渣呢! 题目大意: 猪脚要解决问题, 他有个习惯,每次只解决比之前解决过的问题的难度要大. 他给我们一个矩阵 矩阵的 i 行 j ...
 - HDU 6264 (深搜,数论)
		
题目链接 题意 求\(\sum_{d|n}\phi (d) \times {n\over d}\),其中\(\phi(n) = n\prod_{p|n}({1-{1\over p}})\) 分析 将\ ...
 
随机推荐
- iOS 多尺寸屏幕适配
			
Point Point可以理解为iOS程序员眼中的大小单位.它是iOS操作系统中的抽象的概念. Rendered Pixels可以理解为UI设计师眼中的大小单位. Physical Pixels 设备 ...
 - MySQL分表操作的例子
			
USE project;DROP PROCEDURE IF EXISTS project.delete_test_user;delimiter $$CREATE PROCEDURE project.d ...
 - codevs 3278 最小m 段和问题
			
时间限制: 1 s 空间限制: 256000 KB 题目等级 : 黄金 Gold 题目描述 Description 给定 n 个整数(不一定是正整数)组成的序列,现在要求将序列分割为 m 段,每段 ...
 - css3 省略号
			
overflow: hidden; text-overflow: ellipsis; white-space: nowrap; 也无需给元素设置固定宽度!
 - java 核心技术卷一笔记 6 .1.接口 lambda 表达式 内部类
			
6.1.2 接口不是类,不能实例化一个接口:但是可以声明接口的变量:Comparable x; 接口变量必须引用实现了接口的类对象:x = new Employee(); 检查一个对象是否属于某 ...
 - Robot Framework(十一) 执行测试用例——后处理输出
			
3.3后处理输出 在测试执行期间生成的XML输出文件可以在之后由rebot工具进行后处理,该工具是Robot Framework的组成部分.在测试执行期间生成测试报告和日志时会自动使用它,但在执行后也 ...
 - 【转】IntelliJ 创建main函数快捷
			
http://blog.csdn.net/tiantiandjava/article/details/42269173 今天偶然发现了IntelliJ中 创建main函数的快捷键,依次还有for循环, ...
 - Java获取字符串里面的重复字符
			
public static void main(String[] args) { String word="天地玄黄宇宙洪荒" + "日月盈昃辰宿列张" + & ...
 - struts2基于注解的action
			
使用注解来配置Action的最大好处就是可以实现零配置,但是事务都是有利有弊的,使用方便,维护起来就没那么方便了. 要使用注解方式,我们必须添加一个额外包:struts2-convention-plu ...
 - Vue构建项目
			
构建Vue项目 按照官网教程安装 //先安装脚手架 cnpm i -g vue-cli //查看项目目标列表: webpack browserify pwa 等项目模板 vue list //使用we ...