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从起点开始搜索,只不 ...
随机推荐
- 一款简洁而强大的前端框架JQUery—动画效果及剪刀石头布小游戏
jQuery是什么? jQuery是一个快速.简洁的JavaScript框架,它封装JavaScript常用的功能代码,提供一种简便的JavaScript设计模式,优化HTML文档操作.事件处理.动画 ...
- 笨鸟先飞之ASP.NET MVC系列之过滤器(01过滤器简介)
过滤器 什么是过滤器? 过滤器(Filter) 主要的作用大致可以理解为把我们的附加逻辑注入到MVC框架的请求处理. 在ASP.NET MVC的请求处理中一种有19个管道事件分别是 BeginRequ ...
- 关于Class对象、类加载机制、虚拟机运行时的内存布局的全面解析和推测
简介: 本文是对Java的类加载机制,Class对象,反射原理等相关概念的理解.验证和Java虚拟机中内存布局的一些推测.本文重点讲述了如何理解Class对象以及Class对象的作用. 欢迎探讨,如有 ...
- zoj1797 Least Common Multiple 最小公倍数
Least Common Multiple Time Limit: 2 Seconds Memory Limit: 65536 KB The least common multiple (L ...
- c# xml操作类 比较齐全
using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Secu ...
- 在C#中实现串口通信的方法
通常,在C#中实现串口通信,我们有四种方法: 第一:通过MSCOMM控件这是最简单的,最方便的方法.可功能上很难做到控制自如,同时这个控件并不是系统本身所带,所以还得注册,不在本文讨论范围.可以访问h ...
- WPF中的imagesource 和内存图片的处理
[转载]ImageSource的使用心得 很多时候,我们会使用图片来装饰UI,比如作为控件背景等. 而这些图片可以分为两种形式,即存在于本地文件系统中的图片和存在于内存中的图片 对于这两种形式的图片, ...
- PWA学习心得
PWA学习心得 一.什么是PWA Progressive Web App , (渐进式增强 WEB 应用) 简称 PWA ,是提升WebApp的体验的一种新方法,能给用户原生应用的体验. PWA ...
- ViewPager使用记录1——展示固定数据
ViewPager是v4支持库中的一个控件,相信几乎所有接触Android开发的人都对它不陌生.之所以还要在这里翻旧账,是因为我在最近的项目中有多个需求用到了它,觉得自己对它的认识不够深刻.我计划从最 ...
- 浅谈oracle树状结构层级查询之start with ....connect by prior、level及order by
浅谈oracle树状结构层级查询 oracle树状结构查询即层次递归查询,是sql语句经常用到的,在实际开发中组织结构实现及其层次化实现功能也是经常遇到的,虽然我是一个java程序开发者,我一直觉得只 ...