【题目链接】:http://codeforces.com/problemset/problem/196/B

【题意】



给你一个n*m的棋盘;

然后你能够无限复制这个棋盘;

在这个棋盘上你有一个起点s;

然后问你,你能不能从这个起点s开始一直走无限远;

【题解】



考虑两个不同棋盘上的点(x1,y1),(x2,y2)(即复制出的另外一个棋盘);

假设他们在第一个棋盘上对应的投影x%n,y%m是相同的;

且它们都能由起点S到达;

即S能到达这两个点;

则可知;

可以从S到达其中的一个点(x1,y1);

然后从那个点再到起点,然后再到另外一个棋盘上的(x2,y2),然后再一直重复上述步骤,再回到(x1,y1)再到(x2,y2)..就能无限延伸了;

必要性是靠直觉的吧;

感觉就是要能一直从一个点然后又回到这个点,才能一直扩展嘛;

做法就是dfs(x,y);

看看vis[x%n][y%m]存的是不是(x,y);

不是的话就输出有解;

(vis[x%n][y%m]和(x,y)就是上面对应的(x1,y1)和(x2,y2) )

否则结束这一层递归;



【Number Of WA】



1



【完整代码】

#include <bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define ms(x,y) memset(x,y,sizeof x)
#define Open() freopen("F:\\rush.txt","r",stdin)
#define Close() ios::sync_with_stdio(0),cin.tie(0) typedef pair<int,int> pii;
typedef pair<LL,LL> pll; const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0);
const int M = 1500+10; bool a[M][M],bo[M][M];
pii vis[M][M];
int n,m,x,y;
char s[M]; void out(){
cout <<"Yes"<<endl;
exit(0);
} void dfs(int x,int y){
int tx = (x%n+n)%n,ty = (y%m+m)%m;
if (!a[tx][ty]) return;
if (bo[tx][ty]){
if (vis[tx][ty].fi !=x || vis[tx][ty].se != y)
out();
return;
}
else
bo[tx][ty] = true,vis[tx][ty] = mp(x,y);
rep1(i,1,4){
int tx = x+dx[i],ty = y+dy[i];
dfs(tx,ty);
}
} int main(){
//Open();
Close();//scanf,puts,printf not use
//init??????
cin >> n >> m;
rep1(i,0,n-1){
cin >>s;
rep1(j,0,m-1){
if (s[j]=='#')
a[i][j] = 0;
else{
a[i][j] = 1;
if (s[j]=='S'){
x = i,y = j;
}
}
}
}
dfs(x,y);
cout <<"No"<<endl;
return 0;
}

最新文章

  1. CSS魔法堂:小结一下Box Model与Positioning Scheme
  2. [OC笔记] Category分类之见解
  3. 多版本python共存
  4. PHP检测终端设备是平板、手机还是电脑
  5. win 10 远程连接出现 &quot;由于安全设置错误, 客户端无法连接到远程计算机. 确定你已登录到网络后.” 错误
  6. 线性表集合A=A B
  7. 电脑cmos是什么?和bois的区别?
  8. Hard Parse&amp;amp;Soft Parse
  9. 使用 Passenger +Apache扩展 Puppet,代替其Webrick的web框架
  10. CF Manthan, Codefest 16 G. Yash And Trees 线段树+bitset
  11. Ubuntu 14.04下Redis安装报错:“You need tcl 8.5 or newer in order to run the Redis test”问题解决
  12. CentOS7系统上的LAPACK源码安装
  13. Wpf窗口中打开WinForm窗口
  14. 004 使用SpringMVC开发restful API二--编写用户详情
  15. STL next_permutation 算法原理和实现
  16. jsp 假分页的实现
  17. 洗礼灵魂,修炼python(14)--模块decimal, fractions,operator,collections以及精度介绍
  18. 深入理解 JS 引擎执行机制(同步执行、异步执行以及同步中的异步执行)
  19. hbase与hive集成:hive读取hbase中数据
  20. Git branch 分支与合并分支

热门文章

  1. [LUOGU]P3701 主席树(假的)
  2. centos7下部署FastDFS分布式文件系统
  3. win10开机时内存使用率达到99%以上
  4. sql 语句中的 (+) 是什么意思?
  5. HDU 1211
  6. MongoDB创建\更新\删除文档操作
  7. Unsupported major.minor version 51.0问题的解决
  8. &amp;quot;浪潮杯&amp;quot;第六届ACM山东省省赛山科场总结
  9. CxImage的使用及基本用法
  10. sts安装出现could not find jar:file解决办法,could not find jar:file,sts安装