原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1175

连连看

Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 23190    Accepted Submission(s): 5718

Problem Description
“连连看”相信很多人都玩过。没玩过也没关系,下面我给大家介绍一下游戏规则:在一个棋盘中,放了很多的棋子。如果某两个相同的棋子,可以通过一条线连起来(这条线不能经过其它棋子),而且线的转折次数不超过两次,那么这两个棋子就可以在棋盘上消去。不好意思,由于我以前没有玩过连连看,咨询了同学的意见,连线不能从外面绕过去的,但事实上这是错的。现在已经酿成大祸,就只能将错就错了,连线不能从外围绕过。
玩家鼠标先后点击两块棋子,试图将他们消去,然后游戏的后台判断这两个方格能不能消去。现在你的任务就是写这个后台程序。

  

Input
输入数据有多组。每组数据的第一行有两个正整数n,m(0<n<=1000,0<m<1000),分别表示棋盘的行数与列数。在接下来的n行中,每行有m个非负整数描述棋盘的方格分布。0表示这个位置没有棋子,正整数表示棋子的类型。接下来的一行是一个正整数q(0<q<50),表示下面有q次询问。在接下来的q行里,每行有四个正整数x1,y1,x2,y2,表示询问第x1行y1列的棋子与第x2行y2列的棋子能不能消去。n=0,m=0时,输入结束。
注意:询问之间无先后关系,都是针对当前状态的!

  

  

Output
每一组输入数据对应一行输出。如果能消去则输出"YES",不能则输出"NO"。

  

  

Sample Input
3 4 1 2 3 4 0 0 0 0 4 3 2 1 4 1 1 3 4 1 1 2 4 1 1 3 3 2 1 2 4 3 4 0 1 4 3 0 2 4 1 0 0 0 0 2 1 1 2 4 1 3 2 3 0 0

  

Sample Output
YES NO NO NO NO YES
 
之前用DFS写了一次,内存超了。于是用BFS重写了一次。
 
注意满足条件的判断,这个稍微有一点复杂。应该有初始情况两个数不相等的情况。

注意题目要求“线的转折次数不超过两次”,我没有算转折点,我算的折线数目。(≤3)

 #include <stdio.h>
#include <string.h>
#include <queue>
#include <iostream>
using namespace std;
int n, m, s;
int map[][];
int vis[][];
int x1, y1, x2, y2;
int dir[][]={{,},{-,},{,},{,-}};
typedef struct Position
{
int x, y;
int count;
}Position; int BFS()
{
queue<Position> q;
Position fst, tmp;
fst.x = x1;
fst.y = y1;
fst.count = -; //init. first one not calculate.
q.push(fst);
vis[x1][y1] = ;
int sum;
while(!q.empty())
{
fst = q.front();
q.pop();
for(int i = ; i < ; i++)
{
tmp.x = fst.x + dir[i][];
tmp.y = fst.y + dir[i][];
if(fst.count == i)
{
sum = vis[fst.x][fst.y];
}
else
{
sum = vis[fst.x][fst.y] + ;
}
tmp.count = i;
if( tmp.x >= &&
tmp.x < n &&
tmp.y >= &&
tmp.y < m &&
(vis[tmp.x][tmp.y] == || sum <= vis[tmp.x][tmp.y]))
{
vis[tmp.x][tmp.y] = sum;
if(tmp.x == x2 && tmp.y == y2)
{
if(vis[tmp.x][tmp.y] <= )
{
return ;
}
}
if(vis[tmp.x][tmp.y] > )
{
continue;
}
if(map[tmp.x][tmp.y] == )
{
q.push(tmp);
}
}
}
}
return ;
} int main()
{
while(scanf("%d%d",&n,&m) != EOF && n+m)
{
for(int i = ; i < n; i++)
{
for(int j = ; j < m; j++)
{
scanf("%d", &map[i][j]);
}
}
scanf("%d", &s);
for(int i = ; i < s; i++)
{
scanf("%d %d %d %d", &x1, &y1, &x2, &y2);
x1--;
x2--;
y1--;
y2--;
if((map[x1][y1] != map[x2][y2]) ||
map[x1][y1] == ||
map[x2][y2] == ||
(x1==x2&&y1==y2))
{
printf("NO\n");
continue;
}
memset(vis, , sizeof(vis));
if(BFS())
{
printf("YES\n");
}
else
{
printf("NO\n");
}
} }
return ;
}

[HDOJ1175]连连看的更多相关文章

  1. HDOJ1175连连看 DFS

    连连看 Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submiss ...

  2. hdoj1175 连连看(dfs+剪枝)

    处理连连看问题. 要求拐弯方向不多于两次.剪枝很重要!!! 用dir记录当前方向.Orz,居然没想到. #include<iostream> #include<cstring> ...

  3. (DFS)hdoj1175:连连看

    题目链接 这道题被稍微改编当作过去年的期末上机题,也被直接放到了这次这一届的第二次练习赛.当初刚看到这道题时DFS并没有系统的学过,做起来极其费劲.现在学过之后开始实践练习,发现这道题真的是很水. 我 ...

  4. 传智播客--XAML布局--连连看界面(小白内容)

    一个简单的10*10连连看,有100个格子,可以在XAML里面用ColumnDefinition和RowDefinition各写10组,但是这样效率会很慢,因此,可以采用动态生成的方式进行. publ ...

  5. 连连看游戏(dfs)【华为上机题目】

    1 连连看游戏 今天同学给我做了道编程题目,貌似是华为的,题目描述大概是这样的: 给定一个连连看棋盘,棋盘上每个点都有各种图案(用非0数字表示),输入棋盘上的任意两个左标,判断这两个坐标对应的图案是否 ...

  6. mfc 连连看3.2 修改器

    内涵图 连连看3.2下载

  7. JavaScript写一个连连看的游戏

    天天看到别人玩连连看, 表示没有认真玩过, 不就把两个一样的图片连接在一起么, 我自己写一个都可以呢. 使用Javascript写了一个, 托管到github, 在线DEMO地址查看:打开 最终的效果 ...

  8. 连连看[HDU1175]

    连连看 Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submi ...

  9. Android 绿豆蛙版连连看(简陋版)

    (里面有六张绿豆蛙的图片) 1.选中会有红色框 2.可以直线连(横竖相邻或是横竖间隔空格) 3.可以拐一次弯连接 4.可以拐两次弯连接 5.连接时会有线显示 6.绿色代表进度条,蓝色代表时间条 imp ...

随机推荐

  1. knockout之各种数据绑定方法:text、attr、visible、html、css、style绑定

    http://knockoutjs.com/documentation/attr-binding.html(Knockout官网文档) 1.text绑定 目的:text 绑定到DOM元素上,使得该元素 ...

  2. HttpHandler和ashx要实现IRequiresSessionState接口才能访问Session信息(转载)

    通常我们经常,通过session判定用户是否登录.还有一些临时的.重要的数据也尝尝存放在Session中. 在页面我们很容易的得到Session的值,但在类中就会遇到一些问题.也知道通过下面的方法得到 ...

  3. 蒙地卡罗法求 PI

    问题: 蒙地卡罗为摩洛哥王国之首都,该国位于法国与义大利国境,以赌博闻名.蒙地卡罗的基本原理为以乱数配合面积公式来进行解题,这种以机率来解题的方式带有赌博的意味,虽然在精确度上有所疑虑,但其解题的思考 ...

  4. Native OR WebApp ?

    前两天刚好和一帮产品同学聊过,特指一个APP里面的各页面应该怎么做,大家的总结如下,原理一样,关键是了解Native和Web各自的优劣势:1. 偏交互的Native,偏浏览的Web:交互指复杂操作,输 ...

  5. Android webview实现上传图片的效果(图片压缩)

    mainactivity代码 package com.bwie.webviewupload; import java.io.ByteArrayInputStream; import java.io.B ...

  6. python PIL安装

    PIL:Python Imaging Library,已经是Python平台事实上的图像处理标准库了.PIL功能非常强大,但API却非常简单易用. 安装PIL 在Debian/Ubuntu Linux ...

  7. React笔记_(1)_react概述

    React概述   React是一种很好的前端技术. 它将应用打散成独立的小模块,然后进行组装,完成开发. react远比angularjs难学的多. react依赖的如webpack等各种工具得先学 ...

  8. oracle 自动关闭 数据库连接

    数据库启动后过一会自动断开连接(大概10分钟)    方法一.直接修改资源配置文件     分三个步骤在sqlplus环境下完成.     第一步,查询资源文件,找到CONNECT_TIME所在的pr ...

  9. Facebook MyRocks at MariaDB

    Recently my colleague Rasmus Johansson announced that MariaDB is adding support for the Facebook MyR ...

  10. 26、Oracle(二)

    1)掌握多行函数与分组操作 2)掌握多表查询与子查询 3)理解集合查询与掌握Oracle分页语法 4)理解创建.修改和删除表和表约束 --------------------------------- ...