codeforces510B
Fox And Two Dots
Fox Ciel 正在玩一个手机拼图游戏,被称之为 "Two Dots"。基础关卡是在一个大小为 n × m的棋盘上游戏,类似于这样:

每个单元格包含了一个具有某种颜色的点。我们将使用不同的大写拉丁字符,表示不同的颜色。
这个游戏的关键是,找到同色环。例如,考虑图上的 4 个蓝色点,它们形成了一个环。正式地,我们将一个点序列 d1, d2, ..., dk 称作一个环 ,当且仅当它满足以下的条件:
- 这 k 个点不同:如果 i ≠ j 那么 di 与 dj 不同。
- k 至少是 4。
- 全部的点属于同一种颜色。
- 对于全部的 1 ≤ i ≤ k - 1: di 和 di + 1 邻接,且 dk 与 d1 也邻接。单元格 x 和 y 被称为邻接,如果它们共享一条边。
判断图中是否存在一个环 。
输入
第一行包含两个整数 n 和 m (2 ≤ n, m ≤ 50),分别表示棋盘上的行数和列数。
接下来的 n 行,每行包含一个字符串,该字符串含有 m 个字符,表示每行中的点的颜色。每个字符都是一个大写拉丁字母。
输出
如果存在一个环,则输出 "Yes" ,否则输出 "No" 。
示例
3 4
AAAA
ABCA
AAAA
Yes
3 4
AAAA
ABCA
AADA
No
4 4
YYYR
BYBY
BBBY
BBBY
Yes
7 6
AAAAAB
ABBBAB
ABAAAB
ABABBB
ABAAAB
ABBBAB
AAAAAB
Yes
2 13
ABCDEFGHIJKLM
NOPQRSTUVWXYZ
No
备注
在第一个示例中,全部的 'A' 形成了一个环。
在第二个示例中,不存在环。
第三个示例,如上图所示 ('Y' = 黄色, 'B' = 蓝色, 'R' = 红色)。
sol:只是找一个环可以用dfs轻松解决,因为有个数限制,所以多记一个变量表示走到当前这个位置经过了多少个点,如果再次走到另一个已经访问过的位置就可以判断一下(可以假装像前缀和一样)
#include <bits/stdc++.h>
using namespace std;
typedef int ll;
inline ll read()
{
ll s=;
bool f=;
char ch=' ';
while(!isdigit(ch))
{
f|=(ch=='-'); ch=getchar();
}
while(isdigit(ch))
{
s=(s<<)+(s<<)+(ch^); ch=getchar();
}
return (f)?(-s):(s);
}
#define R(x) x=read()
inline void write(ll x)
{
if(x<)
{
putchar('-'); x=-x;
}
if(x<)
{
putchar(x+''); return;
}
write(x/);
putchar((x%)+'');
return;
}
#define W(x) write(x),putchar(' ')
#define Wl(x) write(x),putchar('\n')
const int N=;
const int dx[]={-,,,},dy[]={,,-,};
int n,m,SX,SY;
char Map[N][N];
bool Arr[N][N];
int Ges[N][N];
inline bool dfs(int x,int y)
{
int i;
Arr[x][y]=;
for(i=;i<;i++)
{
int xx=x+dx[i],yy=y+dy[i];
if(xx<||xx>n||yy<||yy>m) continue;
if(Map[xx][yy]==Map[x][y])
{
if(!Ges[xx][yy])
{
Ges[xx][yy]=Ges[x][y]+;
if(dfs(xx,yy)) return true;
Ges[xx][yy]=;
}
else
{
if(Ges[x][y]-Ges[xx][yy]+>=) return true;
}
}
}
return false;
}
int main()
{
int i,j;
R(n); R(m);
for(i=;i<=n;i++)
{
scanf("%s",Map[i]+);
}
for(i=;i<=n;i++)
{
for(j=;j<=m;j++) if(!Arr[i][j])
{
Ges[i][j]=;
if(dfs(i,j)) return *puts("Yes");
}
}
puts("No");
return ;
}
/*
input
3 4
AAAA
ABCA
AAAA
output
Yes input
3 4
AAAA
ABCA
AADA
output
No input
4 4
YYYR
BYBY
BBBY
BBBY
output
Yes input
7 6
AAAAAB
ABBBAB
ABAAAB
ABABBB
ABAAAB
ABBBAB
AAAAAB
output
Yes input
2 13
ABCDEFGHIJKLM
NOPQRSTUVWXYZ
output
No
*/
codeforces510B的更多相关文章
- Codeforces510B【dfs】
判断一个图里是否有一个自环: 50*50 标记起点,然后暴搜? #include <bits/stdc++.h> #include<algorithm> using names ...
随机推荐
- Luogu P2700 逐个击破
qwq 同关押罪犯 对于这种希望几个对象分开的题目,只要把并查集反过来想就可以了. 既然要求删除的边权最小,那么只要反过来求给定的点不连通时保留的边权最大即为正解. 同样的,首先将边权排序,不会使敌人 ...
- Android 解决启动页白屏或者黑屏的问题
欢迎页启动的线程由于请求和处理的数据量过大而,导致欢迎页在出现之前界面上会有一个短暂的白色闪屏停留,当然白色闪屏的停留是因为 application 的主题样式android:theme=@style ...
- NPOI DataSet导出excel
/// <summary> /// DataSet导出到Excel的MemoryStream /// </summary> /// <param name="d ...
- MYSQL表情存储数据库报错
1.windows安装5.5.5.9的服务器 2.打开window服务找到mysql的服务,右键属性查看路径 3.打开路径,修改mysql配置文件my.ini 4.修改[client]中的defaul ...
- NOIP2002-2017普及组题解
虽然普及组一般都是暴力省一,但是有一些题目还是挺难的qwq个人觉得能进TG的题目会在前面打上'*' NOIP2002(clear) #include<bits/stdc++.h> usin ...
- React-使用react-redux
react-redux可以方便在react中使用redux,我们就可以忘记subscribe,只需要记住reducer,action和dispatch就可以了.react-redux提供Provide ...
- Luogu P2286 [HNOI2004]宠物收养场
一道比较简单的直接Treap运用题目,思维难度和代码难度都不是很高. 题意有点长,我们仔细剖析一下题意发现以下几个关键: 任何时候收养站里只可能有人和宠物中的其中一种,或者都没有 如果只有宠物并有人来 ...
- 详解javascript中this的工作原理
在 JavaScript 中 this 常常指向方法调用的对象,但有些时候并不是这样的,本文将详细解读在不同的情况下 this 的指向. 一.指向 window: 在全局中使用 this,它将会指向全 ...
- vue开发小结(下)
前言 继前几天总结了vue开发小结(上)后,发现还有很多的点没有能列举出来,于是还是打算新建一个下篇,再补充一些vue开发中需要注意的细节,确实还是都是细节的问题,我只是在这里强调下,希望对大家有帮助 ...
- M2贡献分分配方案
1.初始分每个人都为0. 2.每周分配任务,按任务计分. 3.每周每个人有12.5分. 4.次周完成本周任务计6分. 5.未全部完成本周任务计6分. 6.12月29日统计分数,多出来的分数按完成任务数 ...