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从起点开始搜索,只不 ...
随机推荐
- nodejs 初次链接 mongodb 的详细细节
时间 2016-06-2613:05:16 在前端的学习也有一段时间了,学习了html,css,javascript,jqery,ajax,php,mysql,学习了这些,了解了一些皮毛,也没有什么 ...
- 翻译:MariaDB wait/nowait
本文为mariadb官方手册:wait/nowait的译文.原文:https://mariadb.com/kb/en/library/wait-and-nowait/ 从MariaDB 10.3.0开 ...
- AngularJS–service(服务)
点击查看AngularJS系列目录 转载请注明出处:http://www.cnblogs.com/leosx/ 服务 Angular的服务也是使用依赖注入(dependency injection ( ...
- Writing Science 7.10 (The Opening and The Funnel)
Opening: 1.文章的第一句话必须要达到如下目标:找出推动研究的问题,介绍内容,并确定本文针对的观众.如果你足够聪明的话甚至可以将遇到的挑战以及结论写进来. 2.通过第一段话建立本文的重点和基调 ...
- 简易RPC框架-心跳与重连机制
*:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...
- 原创:工作指派问题解决方案---模拟退火算法C实现
本文忽略了对于模拟退火的算法的理论讲解,读者可参考相关的博文或者其他相关资料,本文着重于算法的实现: /************************************************ ...
- WPF控件 在XP下获得焦点有虚线框
所有 Button.ListBox等控件获得焦点时有虚线框.如图:选中523这个按钮就出线虚框. 我在App.xaml中添加适应所有按钮的样式,无效 <Style TargetType=&qu ...
- Android 发展史
1. 概述 http://zh.wikipedia.org/wiki/Android# 2. Android版本发布表 Time Code name Version API level 2014年1 ...
- Java常用类(一)String类详解
前言 在我们开发中经常会用到很多的常用的工具类,这里做一个总结.他们有很多的方法都是我们经常要用到的.所以我们一定要把它好好的掌握起来! 一.String简介 1.1.String(字符串常量)概述 ...
- 【转】Sizeof与Strlen的区别与联系
原文地址:http://www.cnblogs.com/carekee/articles/1630789.html 1.sizeof sizeof(...)是运算符,在头文件中typedef为uns ...