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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

uva 10047 the monocyle (四维bfs)

發布時間:2025/3/21 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 uva 10047 the monocyle (四维bfs) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

算法指南白書

維護一個四維數組,走一步更新一步

1 #include<cstdio> 2 #include<cstring> 3 #include<queue> 4 #include<algorithm> 5 using namespace std; 6 7 const int INF = 1000000000; 8 const int maxr = 25 + 5; 9 const int maxc = 25 + 5; 10 int R, C, sr, sc, tr, tc; 11 char maze[maxr][maxc]; 12 13 struct State { 14 int r, c, dir, color; 15 State(int r, int c, int dir, int color):r(r),c(c),dir(dir),color(color) {} 16 }; 17 18 const int dr[] = {-1,0,1,0}; // north, west, south, east 19 const int dc[] = {0,-1,0,1}; 20 int d[maxr][maxc][4][5], vis[maxr][maxc][4][5];//橫坐標,縱坐標,方向,顏色 21 22 int ans; 23 queue<State> Q; 24 25 void update(int r, int c, int dir, int color, int v) { 26 if(r < 0 || r >= R || c < 0 || c >= C) return; // 不能走出邊界 27 if(maze[r][c] == '.' && !vis[r][c][dir][color]) { 28 Q.push(State(r, c, dir, color)); 29 vis[r][c][dir][color] = 1; 30 d[r][c][dir][color] = v; 31 if(r == tr && c == tc && color == 0) ans = min(ans, v); // 更新答案 32 } 33 } 34 35 void bfs(State st) { 36 d[st.r][st.c][st.dir][st.color] = 0; 37 vis[st.r][st.c][st.dir][st.color] = 1; 38 Q.push(st); 39 while(!Q.empty()) { 40 st = Q.front(); 41 Q.pop(); 42 int v = d[st.r][st.c][st.dir][st.color] + 1; 43 update(st.r, st.c, (st.dir+1)%4, st.color, v); // 左轉 44 update(st.r, st.c, (st.dir+3)%4, st.color, v); // 右轉 45 update(st.r+dr[st.dir], st.c+dc[st.dir], st.dir, (st.color+1)%5, v); // 前進 46 } 47 } 48 49 int main() { 50 int kase = 0; 51 while(scanf("%d%d", &R, &C) == 2 && R && C) { 52 for(int i = 0; i < R; i++) { 53 scanf("%s", maze[i]); 54 for(int j = 0; j < C; j++) 55 if(maze[i][j] == 'S') { 56 sr = i; 57 sc = j; 58 } else if(maze[i][j] == 'T') { 59 tr = i; 60 tc = j; 61 } 62 } 63 maze[sr][sc] = maze[tr][tc] = '.'; 64 ans = INF; 65 memset(vis, 0, sizeof(vis)); 66 bfs(State(sr, sc, 0, 0)); 67 68 if(kase > 0) printf("\n"); 69 printf("Case #%d\n", ++kase); 70 if(ans == INF) printf("destination not reachable\n"); 71 else printf("minimum time = %d sec\n", ans); 72 } 73 } View Code

?

轉載于:https://www.cnblogs.com/ITUPC/p/5312976.html

總結

以上是生活随笔為你收集整理的uva 10047 the monocyle (四维bfs)的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 国产精品自拍视频一区 | 青青草一区 | 丰满人妻熟妇乱偷人无码 | 91porn破解版 | 成人午夜影视在线观看 | 樱桃av| 99视频观看| 丝袜av网站| 日本不卡在线视频 | 巨胸大乳www视频免费观看 | 欧美日韩xxxx | 一区二区三区国产av | 亚洲视频123 | 国产精品久久久久国产a级 国产一区二区在线播放 | 超碰网站在线观看 | 色老头在线一区二区三区 | av手机网站 | 五月婷婷视频在线观看 | 日本一级一片免费视频 | 交做爰xxxⅹ性爽 | 欧美视频免费看欧美视频 | 久久久久久久久91 | 极品一区| 4438x全国最大成人 | 91久久精品www人人做人人爽 | 污污的视频网站在线观看 | 一级片自拍 | 69精品丰满人妻无码视频a片 | 国产精品免费av一区二区 | av天堂一区 | 呦女精品 | 日韩中文字幕在线一区 | 日本xxx高清 | 激情内射人妻1区2区3区 | 国产探花在线精品一区二区 | 日韩亚洲欧美精品 | 亚洲欧美日韩激情 | 91免费国产在线观看 | 黄视频在线播放 | 日韩免费av | 他趴在我两腿中间添得好爽在线看 | 国产无遮挡又黄又爽免费视频 | 国产美女主播在线观看 | 国产免费福利视频 | 特黄视频免费看 | 国产精品怡红院 | 三级欧美日韩 | 一区二区三区在线视频免费观看 | 亚洲精品电影在线观看 | 亚洲第一国产 | 精品区在线观看 | 视频在线日韩 | 日韩一级精品 | 国产在线视频一区 | 成年人在线观看av | 狠狠插影院 | 亚洲激情久久 | 国产精品视频免费网站 | 国产91精品一区二区绿帽 | 亚洲精品白浆 | 五月开心激情网 | 日韩一区不卡 | 成人毛片18女人毛片免费 | 青青草手机在线观看 | 国产高清在线观看 | 一区二区久久久 | 午夜视频成人 | 国产成人在线免费观看视频 | 思思99精品视频在线观看 | 捆绑凌虐一区二区三区 | 精品人妻一区二区三区香蕉 | 亚洲天堂麻豆 | www.av天天 | 91免费国产在线观看 | 国产高潮白浆 | 精品视频免费在线观看 | 九七影院在线观看免费观看电视 | 91一二区| 成人片在线视频 | 中文字幕在线观看日本 | 欧美囗交做爰视频 | 欧美有码在线观看 | 国产乱码精品一区二区三区精东 | 欧美日韩二区三区 | 久久艳片www.17c.com | 欧美1区2区3区4区 | 视频在线观看一区二区三区 | 色97色 | 欧美日韩二三区 | 美女高潮视频在线观看 | 日韩天堂av | 日韩欧美在线观看视频 | 免费观看黄色的网站 | 日本天堂影院 | 女生张开腿让男生插 | 欧美激情一区二区三区四区 | 久久99日韩 | 欧美日韩一区二区三区不卡视频 | 国产日批视频在线观看 |