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从起点开始搜索,只不 ...
随机推荐
- SAP Gateway简介
SAP Gateway在S4/HANA时代的ABAP开发模型中有着重要的地位.SAP Gateway是什么?它对ABAP开发有怎样的影响?可以为我们提供哪些方便?这篇译文将浅要地讨论这些话题. SAP ...
- H5上传图片并使用canvas制作海报
马上就要"十一"国庆节了,又恰逢公司已经三周岁了,所以市场部和产品共同策划了一个"正青春,共成长"的主题代言活动,准备在国庆节以及中秋节期间让公司员工和用户为公 ...
- 51 nod 1624 取余最长路 思路:前缀和 + STL(set)二分查找
题目: 写这题花了我一上午时间. 下面是本人(zhangjiuding)的思考过程: 首先想到的是三行,每一行一定要走到. 大概是这样一张图 每一行长度最少为1.即第一行(i -1) >= 1, ...
- windows访问控制列表 --ACL(Access Control List)
1.定义 ACL是一个windows中的表示用户(组)权限的列表. Access Control List(ACL) Access Control Entry(ACE) ... 2.分类 ACL分为两 ...
- HDU1212
大数MOD #include<cstdio> #include<cstdlib> #include<iostream> #include<algorithm& ...
- EasyUI ComboTree无限层级异步加载示例
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="EasuUIDemoTree.a ...
- 1、Http概述
1.1 Web客户端和服务器 HTTP 客户端和 HTTP 服务器共同构成了万维网的基本组件,客户端向服务器发送 HTTP 请求, 服务器会在 HTTP 响应中回送所请求的数据. 示意图: 1.2 媒 ...
- 张高兴的 Windows 10 IoT 开发笔记:ToF Sensor VL53L0X
GitHub : https://github.com/ZhangGaoxing/windows-iot-demo/tree/master/VL53L0X
- property--staticmethod--classmethod
特性(property): 作为装饰器使用,调用方式从最初的方法调用改变为属性调用 类方法(classmethod):和类进行交互,单不和实例进行交互 在函数中可以不用上传参数 静态方法(static ...
- Oracle学习笔记之用户自定义函数
自定义函数语法格式: 用户自定义的函数,可以直接在sql语句中直接调用,并且任何一个funciton都必须有返回值,而且该函数声明后,是保存在数据端的,我们随时可以使用:注意:函数只能有一个返回值 ...