[HDOJ1175]连连看
原题链接: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
注意题目要求“线的转折次数不超过两次”,我没有算转折点,我算的折线数目。(≤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]连连看的更多相关文章
- HDOJ1175连连看 DFS
连连看 Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submiss ...
- hdoj1175 连连看(dfs+剪枝)
处理连连看问题. 要求拐弯方向不多于两次.剪枝很重要!!! 用dir记录当前方向.Orz,居然没想到. #include<iostream> #include<cstring> ...
- (DFS)hdoj1175:连连看
题目链接 这道题被稍微改编当作过去年的期末上机题,也被直接放到了这次这一届的第二次练习赛.当初刚看到这道题时DFS并没有系统的学过,做起来极其费劲.现在学过之后开始实践练习,发现这道题真的是很水. 我 ...
- 传智播客--XAML布局--连连看界面(小白内容)
一个简单的10*10连连看,有100个格子,可以在XAML里面用ColumnDefinition和RowDefinition各写10组,但是这样效率会很慢,因此,可以采用动态生成的方式进行. publ ...
- 连连看游戏(dfs)【华为上机题目】
1 连连看游戏 今天同学给我做了道编程题目,貌似是华为的,题目描述大概是这样的: 给定一个连连看棋盘,棋盘上每个点都有各种图案(用非0数字表示),输入棋盘上的任意两个左标,判断这两个坐标对应的图案是否 ...
- mfc 连连看3.2 修改器
内涵图 连连看3.2下载
- JavaScript写一个连连看的游戏
天天看到别人玩连连看, 表示没有认真玩过, 不就把两个一样的图片连接在一起么, 我自己写一个都可以呢. 使用Javascript写了一个, 托管到github, 在线DEMO地址查看:打开 最终的效果 ...
- 连连看[HDU1175]
连连看 Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submi ...
- Android 绿豆蛙版连连看(简陋版)
(里面有六张绿豆蛙的图片) 1.选中会有红色框 2.可以直线连(横竖相邻或是横竖间隔空格) 3.可以拐一次弯连接 4.可以拐两次弯连接 5.连接时会有线显示 6.绿色代表进度条,蓝色代表时间条 imp ...
随机推荐
- Native OR WebApp ?
前两天刚好和一帮产品同学聊过,特指一个APP里面的各页面应该怎么做,大家的总结如下,原理一样,关键是了解Native和Web各自的优劣势:1. 偏交互的Native,偏浏览的Web:交互指复杂操作,输 ...
- Oracle体系结构总览(整理)
先让我们来看一张图 这张就是Oracle 9i的架构全图.看上去,很繁杂.是的,是这样的.现在让我们来梳理一下:一.数据库.表空间.数据文件1.数据库数据库是数据集合.Oracle是一种数据库管理系 ...
- bug的约束
1.bug的标题:主模块-子模块-页面-功能描述-bug的描述
- db.properties
jdbc.driverclass=oracle.jdbc.driver.OracleDriverjdbc.url=jdbc:oracle:thin:@192.168.201.192:1521:orcl ...
- 电脑远程工具:mstsc
外网远程控制:电脑远程连接在开始程序中搜:mstsc 然后直接敲IP地址 工具:dell sonicwall netextender.exe mstsc.exe 内网远程控制:使用TeamVi ...
- 数据库日期格式为int型时存取格式
存入当前日期:time() 取出并转化为日期格式:date('Y-m-d H:i:s',strtotime($time)); 最好在前面加上这句: date_default_timezone_set( ...
- MySQL对于数据库应该如何如何配置安全问题了
mysql 是完全网络化的跨平台关系型数据库系统,同时是具有客户机/服务器体系结构的分布式数据库管理系统.它具有功能强.使用简便.管理方便.运行速度快.安全可靠性强等优点,用户可利用许多语言编写访问m ...
- android TextView加载html内容并加载图片
package com.example.textviewfromhtml; import java.net.URL; import android.app.Activity; import andro ...
- java面试每日一题11
题目:求1+2!+3!+...+20!的和 public class Recursion { public static void main(String args[]) throws NumberF ...
- gets()和getchar()还有getch()的区别
getch()和getchar()区别:1.getch(): 所在头文件:conio.h 函数用途:从控制台读取一个字符,但不显示在屏幕上例如: char ch;或int ch: getch();或c ...