日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

信息学奥赛一本通(1252:走迷宫)

發布時間:2025/3/17 编程问答 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 信息学奥赛一本通(1252:走迷宫) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1252:走迷宮


時間限制: 1000 ms ??? ??? 內存限制: 65536 KB
提交數: 12748 ??? 通過數: 5737

【題目描述】

一個迷宮由R行C列格子組成,有的格子里有障礙物,不能走;有的格子是空地,可以走。

給定一個迷宮,求從左上角走到右下角最少需要走多少步(數據保證一定能走到)。只能在水平方向或垂直方向走,不能斜著走。

【輸入】

第一行是兩個整數,R和C,代表迷宮的長和寬。( 1<= R,C <= 40)

接下來是R行,每行C個字符,代表整個迷宮。

空地格子用‘.’表示,有障礙物的格子用‘#’表示。

迷宮左上角和右下角都是‘.’。

【輸出】

輸出從左上角走到右下角至少要經過多少步(即至少要經過多少個空地格子)。計算步數要包括起點和終點。

【輸入樣例】

5 5 ..### #.... #.#.# #.#.# #.#..

【輸出樣例】

9

【分析】

? ? ? ? 典型的迷宮問題,四個方向探索,從(1,1)探索到(n,m)。

【參考代碼】

#include <iostream> #include <queue>using namespace std;const int N=110; struct point {int x,y; //坐標 int step; //步數 }; char a[N][N]; //(1,1)開始地圖 int vis[N][N]; //訪問數組 int m,n; //迷宮行數和列數 int startx,starty; //入口坐標 int decx,decy; //出口坐標 int dx[4]={0,1,0,-1}; //方向數組,右,下,左,上 int dy[4]={1,0,-1,0};void bfs() {queue <point> r; //申請隊列point start; //初始化隊列 start.x=startx;start.y=starty;start.step=1;r.push(start); //起點入隊 vis[startx][starty]=1;while(!r.empty()) //判斷隊列是否為空 {int x=r.front().x; //獲得隊首元素int y=r.front().y;if(x==decx && y==decy){cout << r.front().step;}for(int i=0;i<4;i++) //四個方向擴展{int nx,ny;nx=x+dx[i];ny=y+dy[i];if(a[nx][ny]=='.' && vis[nx][ny]==0) //判斷能不能走 {point temp;temp.x=nx;temp.y=ny;temp.step=r.front().step+1;r.push(temp); //入隊vis[nx][ny]=1; // 標記 }}r.pop();} }int main() {cin >> n >> m;for(int i=1;i<=n;i++)for(int j=1;j<=m;j++)cin >> a[i][j];startx=1;starty=1;decx=n;decy=m;bfs();return 0; }

http://ybt.ssoier.cn:8088/problem_show.php?pid=1252

總結

以上是生活随笔為你收集整理的信息学奥赛一本通(1252:走迷宫)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。