原题链接: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. json_decode和json_encode

    JSON出错:Cannot use object of type stdClass as array解决方法php再调用json_decode从字符串对象生成json对象时,如果使用[]操作符取数据, ...

  2. PL/SQL快捷键

    F8 执行所选中的SQL语句 当光标在sql语句末尾/开头 时 按Shift  Home /Shift  End 选中该语句

  3. scala多个构造函数的定义方法

    直接上代码: package com.test.scalaw.test.demo /** * scala定义多个构造函数, * 另外,Scala中有只有一个主要构造函数,其他都是辅助构造函数.而且需要 ...

  4. iOS 解决的问题

    1. 字符超过一定长度会闪退. 2. 发送完会弹出警告框. 3. 加入语音. 4. 连接按钮做peripheval是否为空的判断.

  5. kvm虚拟机virt-manager启动报错

    安装kvm,用virt-manager启动时报错如下: Traceback (most recent call last):  File "/usr/share/virt-manager/v ...

  6. Java 基本数据类型 sizeof 功能【转】

    转自:http://blog.csdn.net/sunboy_2050/article/details/7310008 版权声明:本文为博主原创文章,未经博主允许不得转载. Java基本数据类型int ...

  7. Temporary InMemory Tables [AX 2012]

    Temporary InMemory Tables [AX 2012] This topic has not yet been rated - Rate this topic Updated: Oct ...

  8. JavaEE基础(十五)/集合

    1.集合框架(对象数组的概述和使用) A:案例演示 需求:我有5个学生,请把这个5个学生的信息存储到数组中,并遍历数组,获取得到每一个学生信息. Student[] arr = new Student ...

  9. 关于ADO.NET@SQL Server&SqlDataReader

    先说基础的,说基础的明白了再深的也是一样的.SQL是关系型数据库,所以就决定了对其操作的时候ADO的一些类要相互联系,Connection 类Command对象(ExecuteReader()方法.E ...

  10. POJ 3903:Stock Exchange(裸LIS + 二分优化)

    http://poj.org/problem?id=3903 Stock Exchange Time Limit: 1000MS   Memory Limit: 65536K Total Submis ...