6264:走出迷宫

简介: 题目链接:http://noi.openjudge.cn/ch0205/6264/总时间限制: 1000ms 内存限制: 65536kB描述当你站在一个迷宫里的时候,往往会被错综复杂的道路弄得失去方向感,如果你能得到迷宫地图,事情就会变得非常简单。

题目链接:http://noi.openjudge.cn/ch0205/6264/

总时间限制: 1000ms 内存限制: 65536kB
描述

当你站在一个迷宫里的时候,往往会被错综复杂的道路弄得失去方向感,如果你能得到迷宫地图,事情就会变得非常简单。 
假设你已经得到了一个n*m的迷宫的图纸,请你找出从起点到出口的最短路。

输入
第一行是两个整数n和m(1<=n,m<=100),表示迷宫的行数和列数。
接下来n行,每行一个长为m的字符串,表示整个迷宫的布局。字符'.'表示空地,'#'表示墙,'S'表示起点,'T'表示出口。
输出
输出从起点到出口最少需要走的步数。
样例输入
3 3
S#T
.#.
...
样例输出
6

算法分析:典型的广搜。

 1 #include<stdio.h>
 2 #include<iostream>
 3 #include<queue>
 4 using namespace std;
 5 
 6 struct obj
 7 {
 8     int xx,yy,step;
 9 };
10 
11 int n,m;
12 char map[102][102];
13 queue<struct obj> q;
14 struct obj S,T;
15 
16 int dx[4]={-1,0,1,0};//上右下左 
17 int dy[4]={0,1,0,-1};
18 void BFS();
19 
20 int main(int argc, char *argv[])
21 {
22     int i,j;
23     scanf("%d%d",&n,&m);getchar();
24     for(i=0;i<n;i++)
25     {
26         for(j=0;j<m;j++)
27         {
28             map[i][j]=getchar();
29             if(map[i][j]=='S')
30             { S.xx=i; S.yy=j; S.step=0;    }
31             else if(map[i][j]=='T')
32             { T.xx=i; T.yy=j; T.step=-1; map[i][j]='.'; }
33         }
34         getchar();
35     }
36     
37     if(S.xx==T.xx&&S.yy==T.yy) printf("0\n");
38     else  BFS();
39     printf("%d\n",T.step);
40     
41     return 0;
42 }
43 
44 void BFS()
45 {
46     int i,txx,tyy;
47     struct obj temp;
48     
49     q.push(S);
50     while(!q.empty())
51     {
52         for(i=0;i<4;i++)
53         {
54             txx=q.front().xx+dx[i];
55             tyy=q.front().yy+dy[i];
56             if(txx>=0&&txx<n&&tyy>=0&&tyy<m&&map[txx][tyy]=='.')
57             {
58                 temp.xx=txx;
59                 temp.yy=tyy;
60                 temp.step=q.front().step+1;
61                 map[txx][tyy]='#';
62                 q.push(temp);
63                 if(temp.xx==T.xx&&temp.yy==T.yy)
64                 {
65                     T.step=temp.step;
66                     return ;
67                 }
68             }
69         }
70         q.pop();
71     }
72 }

 

相关文章
|
存储 算法 索引
给你一个未排序的整数数组 nums ,请你找出其中没有出现的最小的正整数
给你一个未排序的整数数组 nums ,请你找出其中没有出现的最小的正整数
206 1
|
存储 物联网
【洛谷 P1135】奇怪的电梯 题解(广度优先搜索)
这是一个关于奇怪电梯的编程问题摘要: - 电梯在每层停,且每层有特定数字 $K_i$ 决定上/下按钮的功能。 - 目标是从 $A$ 楼到 $B$ 楼,求最少按键次数,若无法到达则输出 `-1`。 - 输入包括 $N$(楼层数)、$A$(起点)和 $B$(终点),以及每层的 $K_i$ 数字。 - 使用广度优先搜索(BFS)解决,通过队列存储访问过的楼层,避免重复并计算步数。 - 当到达目标楼层时返回步数,队列空时返回 `-1`。
267 0
抽签软件免费提供,代码开源,可用作抽奖、课堂抽背、游戏分组等活动场合,可以直接下载
抽签软件免费提供,代码开源,可用作抽奖、课堂抽背、游戏分组等活动场合,可以直接下载
980 1
抽签软件免费提供,代码开源,可用作抽奖、课堂抽背、游戏分组等活动场合,可以直接下载
|
定位技术
DFS:奇偶性剪枝+可行性剪枝
DFS:奇偶性剪枝+可行性剪枝
180 0
|
10天前
|
存储 关系型数据库 分布式数据库
PostgreSQL 18 发布,快来 PolarDB 尝鲜!
PostgreSQL 18 发布,PolarDB for PostgreSQL 全面兼容。新版本支持异步I/O、UUIDv7、虚拟生成列、逻辑复制增强及OAuth认证,显著提升性能与安全。PolarDB-PG 18 支持存算分离架构,融合海量弹性存储与极致计算性能,搭配丰富插件生态,为企业提供高效、稳定、灵活的云数据库解决方案,助力企业数字化转型如虎添翼!
|
9天前
|
存储 人工智能 Java
AI 超级智能体全栈项目阶段二:Prompt 优化技巧与学术分析 AI 应用开发实现上下文联系多轮对话
本文讲解 Prompt 基本概念与 10 个优化技巧,结合学术分析 AI 应用的需求分析、设计方案,介绍 Spring AI 中 ChatClient 及 Advisors 的使用。
410 130
AI 超级智能体全栈项目阶段二:Prompt 优化技巧与学术分析 AI 应用开发实现上下文联系多轮对话
|
3天前
|
存储 安全 前端开发
如何将加密和解密函数应用到实际项目中?
如何将加密和解密函数应用到实际项目中?
199 138
|
9天前
|
人工智能 Java API
AI 超级智能体全栈项目阶段一:AI大模型概述、选型、项目初始化以及基于阿里云灵积模型 Qwen-Plus实现模型接入四种方式(SDK/HTTP/SpringAI/langchain4j)
本文介绍AI大模型的核心概念、分类及开发者学习路径,重点讲解如何选择与接入大模型。项目基于Spring Boot,使用阿里云灵积模型(Qwen-Plus),对比SDK、HTTP、Spring AI和LangChain4j四种接入方式,助力开发者高效构建AI应用。
380 122
AI 超级智能体全栈项目阶段一:AI大模型概述、选型、项目初始化以及基于阿里云灵积模型 Qwen-Plus实现模型接入四种方式(SDK/HTTP/SpringAI/langchain4j)