A91481.幻想迷宫

普及+/提高

官方

通过率:0%

时间限制:1.00s

内存限制:128MB

题目描述

幻象迷宫可以认为是无限大的,不过它是由若干个 N×MN \times M 的矩阵平铺重复组成的。

给出一个 N×MN \times M 的字符矩阵,表示从坐标 (0,0)(0,0)(N1,M1)(N-1,M-1) 这一块区域内的情况:

  • . 表示道路;
  • # 表示墙;
  • S 表示 Welcome24ever 和 fangz 的起始位置(恰好出现一次)。

整个无限迷宫是通过这个 N×MN \times M 的矩阵无限复制平铺得到的。
也就是说,对于无限迷宫中任意一个格子 (x,y)(x,y)x,yx,y 可以是任意整数),如果把它“折回”到基础矩阵中:

    • ix(modN)i \equiv x \pmod N0i<N0 \le i < N
    • jy(modM)j \equiv y \pmod M0j<M0 \le j < M
  • 那么:
    • 若基础矩阵上 (i,j)(i,j) 位置是 .S,则 (x,y)(x,y)道路
    • 若基础矩阵上 (i,j)(i,j) 位置是 #,则 (x,y)(x,y)

Welcome24ever 和 fangz 可以从起点出发,在道路上移动,每一步可以上下左右移动一格,但不能移动到墙上。

如果它们可以走到距离起点任意远的地方(也就是在这个无限的平铺迷宫中,能到达无穷远处),就认为它们能够走出幻象迷宫

现在请你告诉它们:是否能够走出幻象迷宫?

  • 如果能走到距离起点无限远处,输出 Yes
  • 否则输出 No

输入格式

  • 第一行包含两个整数 N,MN, M,表示基础矩阵的行数和列数;
  • 接下来 NN 行,每行一个长度为 MM 的字符串,只包含 .#S,表示从 (0,0)(0,0)(N1,M1)(N-1,M-1) 的这一块区域。

保证每组数据中恰好有一个 S

输出格式

对于每组数据,输出一行:

  • 若 Welcome24ever 和 fangz 能够走到距离起点无限远处,输出:
Yes
  • 否则输出:
No

输入输出样例

  • 输入#1

    5 4
    ##.#
    ##S#
    #..#
    #.##
    #..#

    输出#1

    Yes
  • 输入#2

    5 4
    ##.#
    ##S#
    #..#
    ..#.
    #.##

    输出#2

    No

说明/提示

  • 1N,M15001 \le N, M \le 1500
首页