C语言基础题:迷宫寻路(C语言版)

1.题目描述

机器猫被困在一个矩形迷宫里。

迷宫可以视为一个n x m 矩阵,每个位置要么是空地,要么是墙。机器猫只能从一个空地走到其上、下、左、右的空地。

机器猫初始时位于(1,1)的位置,问能否走到(n,m)位置。

2.输入格式

第一行,两个正整数 n,m。

接下来几行,输入这个迷宫。每行输入一个长为 m 的字符串,#表示墙,. 表示空地。

3.输出格式

仅一行,一个字符串。如果机器猫能走到(n,m),则输出 Yes;否则输出 No 。

4.输入输出样例

1.输入:
cpp 复制代码
3 5
.##.#
.#...
...#.
2.输出:
cpp 复制代码
Yes

5.说明/提示

样例解释

路线如下:(1,1)→(2,1)→(3,1)→(3,2)→(3,3)→(2,3)→(2,4)→(2,5)→(3,5)

数据规模与约定

对于 100% 的数据,保证1< n,m < 100,(1,1)和(n,m)均为空地。

代码:

cpp 复制代码
#include <stdio.h>
#include <stdlib.h>

#define MAXN 1000

typedef struct {
    int x, y;
} Point;

int n, m;
char maze[MAXN][MAXN + 1];
int visited[MAXN][MAXN]; // 访问标记
Point queue[MAXN * MAXN]; // 队列用于 BFS
int front = 0, rear = 0;

// 移动方向:上下左右
int dir[4][2] = {{1, 0}, {-1, 0}, {0, 1}, {0, -1}};

void enqueue(Point p) {
    queue[rear++] = p;
}

Point dequeue() {
    return queue[front++];
}

int is_valid(int x, int y) {
    return (x >= 0 && x < n && y >= 0 && y < m && maze[x][y] == '.' && !visited[x][y]);
}

int bfs() {
    enqueue((Point){0, 0}); // 从 (0,0) 开始
    visited[0][0] = 1; // 标记为已访问

    while (front < rear) {
        Point current = dequeue();
        
        // 如果到达终点 (n-1, m-1)
        if (current.x == n - 1 && current.y == m - 1) {
            return 1; // 可到达
        }

        // 检查四个方向
        for (int i = 0; i < 4; i++) {
            int new_x = current.x + dir[i][0];
            int new_y = current.y + dir[i][1];

            if (is_valid(new_x, new_y)) {
                visited[new_x][new_y] = 1; // 标记为已访问
                enqueue((Point){new_x, new_y}); // 入队
            }
        }
    }
    return 0; // 不可到达
}

int main() {
    scanf("%d %d", &n, &m);
    
    // 读取迷宫
    for (int i = 0; i < n; i++) {
        scanf("%s", maze[i]);
    }

    // 如果起点或终点是墙,直接输出 No
    if (maze[0][0] == '#' || maze[n-1][m-1] == '#') {
        printf("No\n");
        return 0;
    }

    // 执行 BFS
    if (bfs()) {
        printf("Yes\n");
    } else {
        printf("No\n");
    }

    return 0;
}
相关推荐
Boilermaker19921 小时前
[Java 并发编程] Synchronized 锁升级
java·开发语言
MM_MS1 小时前
Halcon变量控制类型、数据类型转换、字符串格式化、元组操作
开发语言·人工智能·深度学习·算法·目标检测·计算机视觉·视觉检测
꧁Q༒ོγ꧂2 小时前
LaTeX 语法入门指南
开发语言·latex
njsgcs2 小时前
ue python二次开发启动教程+ 导入fbx到指定文件夹
开发语言·python·unreal engine·ue
alonewolf_992 小时前
JDK17新特性全面解析:从语法革新到模块化革命
java·开发语言·jvm·jdk
古城小栈2 小时前
Rust 迭代器产出的引用层数——分水岭
开发语言·rust
ghie90902 小时前
基于MATLAB的TLBO算法优化实现与改进
开发语言·算法·matlab
恋爱绝缘体12 小时前
2020重学C++重构你的C++知识体系
java·开发语言·c++·算法·junit
wuk9982 小时前
VSC优化算法MATLAB实现
开发语言·算法·matlab
AI小怪兽2 小时前
基于YOLOv13的汽车零件分割系统(Python源码+数据集+Pyside6界面)
开发语言·python·yolo·无人机