首页 > 其他分享 >P1363 幻象迷宫

P1363 幻象迷宫

时间:2024-09-11 17:05:44浏览次数:10  
标签:WD P1363 int 迷宫 nx ny 幻象 le LHX

题目描述

点击查看题目

题目背景

(喵星人 LHX 和 WD 同心协力击退了汪星人的入侵,不幸的是,汪星人撤退之前给它们制造了一片幻象迷宫。)

WD:呜呜,肿么办啊……

LHX:momo...我们一定能走出去的!

WD:嗯,+U+U!

题目描述

幻象迷宫可以认为是无限大的,不过它由若干个 \(N\times M\) 的矩阵重复组成。矩阵中有的地方是道路,用 \(\verb!.!\) 表示;有的地方是墙,用 \(\verb!#!\) 表示。LHX 和 WD 所在的位置用 \(\verb!S!\) 表示。也就是对于迷宫中的一个点\((x,y)\),如果 \((x \bmod n,y \bmod m)\) 是 \(\verb!.!\) 或者 \(\verb!S!\),那么这个地方是道路;如果 \((x \bmod n,y \bmod m)\) 是\(\verb!#!\),那么这个地方是墙。LHX 和 WD 可以向上下左右四个方向移动,当然不能移动到墙上。

请你告诉 LHX 和 WD,它们能否走出幻象迷宫(如果它们能走到距离起点无限远处,就认为能走出去)。如果不能的话,LHX 就只好启动城堡的毁灭程序了……当然不到万不得已,他不想这么做。

输入格式

输入包含多组数据,以 EOF 结尾。

每组数据的第一行是两个整数 \(N,M\)。

接下来是一个 \(N\times M\) 的字符矩阵,表示迷宫里 \((0,0)\) 到 \((n-1,m-1)\) 这个矩阵单元。

输出格式

对于每组数据,输出一个字符串,Yes 或者 No

样例 #1

样例输入 #1

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

样例输出 #1

Yes
No

提示

  • 对于 \(30\%\) 的数据,\(1\le N,M\le 20\);
  • 对于 \(50\%\) 的数据,\(1\le N,M\le 100\);
  • 对于 \(100\%\) 的数据,\(1\le N,M\le 1500\),每个测试点不超过 \(10\) 组数据。

思路

从起点往外走,坐标取模,如果一个点被走两次,那么证明可以循环往复,判断方法为当前取模以后的坐标和真实的循环坐标是否相等。

代码

#include <bits/stdc++.h>

using namespace std;

const int N = 1510;

char s[N][N];
int n, m;
bool vis[N][N];
int cx[N][N], cy[N][N];

int dx[4] = {1, 0, -1, 0};
int dy[4] = {0, 1, 0, -1};

bool dfs(int x, int y, int lx, int ly) {
    vis[x][y] = 1;
    cx[x][y] = lx;
    cy[x][y] = ly;

    for (int i = 0; i < 4; i++) {
        int nx = x + dx[i];
        int ny = y + dy[i];
        int nlx = lx + dx[i];
        int nly = ly + dy[i];

        nx = (nx % n + n) % n;
        ny = (ny % m + m) % m;
        
        if (s[nx][ny] == '#') continue;
        if (!vis[nx][ny]) {
            if (dfs(nx, ny, nlx, nly)) return true;
        }
        else {
            if ((cx[nx][ny] != nlx) || (cy[nx][ny] != nly)) return true;
        }
    }
    return false;
}

void solve() {
    memset(vis, 0, sizeof(vis));
    for (int i = 0; i < n; i++) cin >> s[i];

    int sx = -1, sy = -1;
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < m; j++) {
            if (s[i][j] == 'S') {
                sx = i, sy = j;
                s[i][j] = '.';
                break;
            }
        }
    }
    if (dfs(sx, sy, sx, sy)) cout << "Yes\n";
    else cout << "No\n";
}

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    while (cin >> n >> m) solve();
    return 0;
}

标签:WD,P1363,int,迷宫,nx,ny,幻象,le,LHX
From: https://www.cnblogs.com/Yuan-Jiawei/p/18408512

相关文章

  • 509迷宫
    想法还是太过于巧妙了。首先有一个很简单的容斥\(n^2\)做法。然后我们能发现\(mod\)很小,注意:\(\forall_{1\lei<mod}\)\(C_{mod}^{i}=0\)。所以就有个天才的做法,将矩阵沿着对角线切开,类似这样:如果我们每隔\(mod\)进行一次切割,那么我们就会发现如果把第\(i\)条......
  • 【C++算法全真练习题】迷宫问题
    目录题目描述思路AC解答题目描述‌题目描述‌:‌给定一个二维迷宫,‌其中 0 表示可以走的路,‌1 表示障碍物。‌起点坐标为 (0,0),‌终点坐标为 (m-1,n-1),‌其中 m 和 n 分别是迷宫的行数和列数。‌你需要使用广度优先搜索(‌BFS)‌找到从起点到终点的一条路径......
  • 迷宫,返回所有路径并排序(C++)(回溯+dfs)
    题意说明:要求给出一个m*n的矩阵迷宫,0代表入口,1代表道路,2代表墙体,3代表出口,要求返回从入口到出口的所有移动路径并按长短从小到大排序。移动路径:就是wasd的移动路径,如一共走三步:下,右,下,则输出:sds。代码如下:#include<iostream>#include<string>#include<vector>#include<alg......
  • C语言阴阳迷宫
    目录开头程序程序的流程图程序游玩的效果下一篇博客要说的东西开头大家好,我叫这是我58。程序#define_CRT_SECURE_NO_WARNINGS1#include<stdio.h>#include<stdlib.h>#include<string.h>#include<Windows.h>enumWASD{ W, A, S, D};enumYYSe{ YI......
  • 牛客小白月赛99 C-迷宫(DFS)
    题目描述给定一个n×m\mathrm{n\timesm}n×m的迷宫,迷宫由"#"与"."两种字符组成。其中"#"代表障碍物,"."表示空地。迷宫中还有一个起点"S"和一个终点"E",它们都可以视为空地。 由于近期迷宫发生了塌方,导致起点和终点之间可能并不连通。幸运的是,你拥有一种超能......
  • 走迷宫小游戏
    #include<stdio.h>#include<conio.h>#include<windows.h>#include<time.h>#defineHeight45#defineWidth45#defineWall1#defineRoad0#defineStart2#defineEnd3#defineEsc5#defineUp1#defineDown2#defineLeft3#d......
  • 洛谷P1605 迷宫
    原题题目描述给定一个方格的迷宫,迷宫里有处障碍,障碍处不可通过。在迷宫中移动有上下左右四种方式,每次只能移动一个方格。数据保证起点上没有障碍。给定起点坐标和终点坐标,每个方格最多经过一次,问有多少种从起点坐标到终点坐标的方案。输入格式第一行为三个正整数,分......
  • 汇编语言之门:深入I/O操作的迷宫
    标题:汇编语言之门:深入I/O操作的迷宫在计算机的微观世界中,汇编语言以其与硬件的紧密联系而著称。输入输出(I/O)操作是汇编语言程序中与外部世界交互的重要手段。本文将带你深入探索汇编语言中的I/O操作,揭示其背后的原理,并展示如何通过代码实现基本的I/O功能。汇编语言与I/O操......
  • 汇编语言之门:深入I/O操作的迷宫
    标题:汇编语言之门:深入I/O操作的迷宫在计算机的微观世界中,汇编语言以其与硬件的紧密联系而著称。输入输出(I/O)操作是汇编语言程序中与外部世界交互的重要手段。本文将带你深入探索汇编语言中的I/O操作,揭示其背后的原理,并展示如何通过代码实现基本的I/O功能。汇编语言与I/O操......
  • 一本通1215:迷宫答案
    #include<bits/stdc++.h>usingnamespacestd;charmp[105][105];boolvis[105][105];intdx[4]={0,0,1,-1};intdy[4]={-1,1,0,0};intfx,fy,sx,sy,n,c,a=0;voiddfs(intx,inty){  if(x==fx&&y==fy)  {    cout<<"YES"&l......