【codeforces 196B】Infinite Maze
2024-10-01 14:05:40
【题目链接】: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;
}
最新文章
- CSS魔法堂:小结一下Box Model与Positioning Scheme
- [OC笔记] Category分类之见解
- 多版本python共存
- PHP检测终端设备是平板、手机还是电脑
- win 10 远程连接出现 ";由于安全设置错误, 客户端无法连接到远程计算机. 确定你已登录到网络后.” 错误
- 线性表集合A=A B
- 电脑cmos是什么?和bois的区别?
- Hard Parse&;amp;Soft Parse
- 使用 Passenger +Apache扩展 Puppet,代替其Webrick的web框架
- CF Manthan, Codefest 16 G. Yash And Trees 线段树+bitset
- Ubuntu 14.04下Redis安装报错:“You need tcl 8.5 or newer in order to run the Redis test”问题解决
- CentOS7系统上的LAPACK源码安装
- Wpf窗口中打开WinForm窗口
- 004 使用SpringMVC开发restful API二--编写用户详情
- STL next_permutation 算法原理和实现
- jsp 假分页的实现
- 洗礼灵魂,修炼python(14)--模块decimal, fractions,operator,collections以及精度介绍
- 深入理解 JS 引擎执行机制(同步执行、异步执行以及同步中的异步执行)
- hbase与hive集成:hive读取hbase中数据
- Git branch 分支与合并分支
热门文章
- [LUOGU]P3701 主席树(假的)
- centos7下部署FastDFS分布式文件系统
- win10开机时内存使用率达到99%以上
- sql 语句中的 (+) 是什么意思?
- HDU 1211
- MongoDB创建\更新\删除文档操作
- Unsupported major.minor version 51.0问题的解决
- &;quot;浪潮杯&;quot;第六届ACM山东省省赛山科场总结
- CxImage的使用及基本用法
- sts安装出现could not find jar:file解决办法,could not find jar:file,sts安装