HDU1175 连连看(DFS)
玩家鼠标先后点击两块棋子,试图将他们消去,然后游戏的后台判断这两个方格能不能消去。现在你的任务就是写这个后台程序。
注意:询问之间无先后关系,都是针对当前状态的!
代码:
#include<iostream>
#include<algorithm>
#include <stdio.h>
#include <string.h>
int a[][],vis[][];
int n,m,x1,x2,y1,y2,flag;
using namespace std;
void dfs(int x,int y,int d,int k)//d(1 up 2 down 3 left 4 right)
{
if(flag) return;
if(k>=) return;
if(x<=||y<=||x>n||y>m) return;//此处x不是x轴!
/* |-------->y
|
|
|
v
x 读入顺序(愚昧的我)*/
if(x==x2&&y==y2)//如果找到了 ,flag设为1
{
flag=;
return;
}
if(k==)//如果已经折了两次,则当前直线必定经过目标点(废话),若不则返回。
{
if(!(d==&&x>x2&&y==y2||d==&&x>x2&&y==y2||d==&&y>y2&&x==x2||d==&&y<y2&&x==x2)) return;
}
if(a[x][y]!=) return;//如果非0为障碍,不能通过,返回
if(vis[x][y]) return;//如果已经经过了,返回
vis[x][y]=;//标记为已经过
if(d==)//现在向上走
{
dfs(x-,y,,k);
dfs(x+,y,,k+);//方向改变了,k+1
dfs(x,y-,,k+);
dfs(x,y+,,k+);
}
if(d==)//现在向下走
{
dfs(x-,y,,k+);
dfs(x+,y,,k);
dfs(x,y-,,k+);
dfs(x,y+,,k+);
}
if(d==)//现在向左走
{
dfs(x-,y,,k+);
dfs(x+,y,,k+);
dfs(x,y-,,k);
dfs(x,y+,,k+);
}
if(d==)//现在向右走
{
dfs(x-,y,,k+);
dfs(x+,y,,k+);
dfs(x,y-,,k+);
dfs(x,y+,,k);
}
vis[x][y]=;//重新标记为未经过
}
int main()
{
while(~scanf("%d%d",&n,&m))
{
if(!n&&!m)//如果均为0
{
break;
}
int i,j;
for (i=;i<=n;i++)
{
for(j=;j<=m;j++)
{
scanf("%d",&a[i][j]);
}
}
int t;
scanf("%d",&t);
while(t--)
{
flag=;
memset(vis,,sizeof(vis));
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
if(x1==x2&&y1==y2&&a[x1][y1]!=)//如果在同一坐标则是错的
{
printf("NO\n");
}
else
{
if(a[x1][y1]==a[x2][y2]&&a[x1][y1])//不同点,要满足值相同且不为0
{
dfs(x1-,y1,,);
dfs(x1+,y1,,);
dfs(x1,y1-,,);
dfs(x1,y1+,,);
if(flag)
printf("YES\n");
else
printf("NO\n");
}
else printf("NO\n");
}
}
}
}
HDU1175 连连看(DFS)的更多相关文章
- hdu1175连连看(dfs+细节)
连连看 Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submi ...
- hdu1175 连连看(bfs疯狂MLE和T,遂考虑dfs+剪枝)
题目链接:http://icpc.njust.edu.cn/Problem/Hdu/1175/ 题目大意就是给出地图,上面有若干的数,相当于连连看,给了q个查询,问给出的两个位置的数能否在两次转弯以内 ...
- HDOJ1175连连看 DFS
连连看 Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submiss ...
- 连连看(dfs)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1175 连连看 Time Limit: 20000/10000 MS (Java/Others) ...
- hdu1175 连连看
连连看 HDU - 1175 “连连看”相信很多人都玩过.没玩过也没关系,下面我给大家介绍一下游戏规则:在一个棋盘中,放了很多的棋子.如果某两个相同的棋子,可以通过一条线连起来(这条线不能经过其它棋子 ...
- POJ2308连连看dfs+bfs+优化
DFS+BFS+MAP+剪枝 题意: 就是给你一个10*10的连连看状态,然后问你最后能不能全部消没? 思路: 首先要明确这是一个搜索题目,还有就是关键的一点就是连连看这个游戏是 ...
- hdu 1175 连连看 DFS
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1175 解题思路:从出发点开始DFS.出发点与终点中间只能通过0相连,或者直接相连,判断能否找出这样的路 ...
- hdu1175连连看
Problem Description “连连看”相信很多人都玩过.没玩过也没关系,下面我给大家介绍一下游戏规则:在一个棋盘中,放了很多的棋子.如果某两个相同的棋子,可以通过一条线连起来(这条线不能经 ...
- HDU 1175 连连看 (DFS+剪枝)
<题目链接> 题目大意:在一个棋盘上给定一个起点和终点,判断这两点是否能通过连线连起来,规定这个连线不能穿过其它的棋子,并且连线转弯不能超过2次. 解题分析:就是DFS从起点开始搜索,只不 ...
随机推荐
- 新建maven项目遇到Select an Archetype时没有maven-archetype-webapp处理方法
[已经有很多博客写过相关的了.详细请去看其他博主的.这里只是记录新建的时候发生的问题给新手提供帮助.因为我跟我的同事都遇到了.因为没记录下来,又花了时间找问题.而网上好像也不多.所以记录下来.希望帮到 ...
- Message:Unable to locate element 问题解决方法
Python断断续续学了有一段时间了,总感觉不找个小项目练练手心里没底,哪成想出门就遇到"拦路虎",一个脚本刚写完就运行报错,还好做足了心里准备,尝试自行解决. 或许网上有相关解决 ...
- [js高手之路] html5新增的定时器requestAnimationFrame实战进度条
在requestAnimationFrame出现之前,我们一般都用setTimeout和setInterval,那么html5为什么新增一个requestAnimationFrame,他的出现是为了解 ...
- BZOJ-1050-[HAOI2006]旅行comf(并查集)
Description 给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000).给你两个顶点S和T,求 一条路径,使得路径上最 ...
- Day4 闭包、装饰器decorator、迭代器与生成器、面向过程编程、三元表达式、列表解析与生成器表达式、序列化与反序列化
一.装饰器 一.装饰器的知识储备 1.可变长参数 :*args和**kwargs def index(name,age): print(name,age) def wrapper(*args,**k ...
- 一脸懵逼学习基于CentOs的Hadoop集群安装与配置
1:Hadoop分布式计算平台是由Apache软件基金会开发的一个开源分布式计算平台.以Hadoop分布式文件系统(HDFS)和MapReduce(Google MapReduce的开源实现)为核心的 ...
- django获取ajax的post复杂对象
一.django的request中post对象为空(即获取不到前台ajax传送的post对象) 1.将django的setting中的django.middleware.csrf.CsrfViewMi ...
- Laravel框架使用查询构造器实现CURD
一.什么是查询构造器? ①Laravel 查询构造器(query Builder)提供方便,流畅的接口,用来建立及执行数据库查找语法 ②使用PDO参数绑定,以保护应用程序免于SQL注入因此传入的参数不 ...
- zabbix基本操作
zabbix基本操作 ---- 2016年终总结 二 包括的内容: 添加主机 查看监控数据 添加监控项 创建触发器 创建模版 添加报警 添加媒介 添加主机 进入页面 点击Configuration(大 ...
- openvswitch 2.7 安装过程记录 总结
envswitch 2.7 安装过程记录 总结 安装思路是参考文档: http://docs.openvswitch.org/en/latest/intro/install/general/#obta ...