青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

A Za, A Za, Fighting...

堅信:勤能補拙

PKU 2312 Battle City (Cont.)

問題:
http://poj.org/problem?id=2312

思路:
http://m.shnenglu.com/Joe/archive/2010/10/23/130973.html中,參考網上代碼采用了一種"新"的BFS方法來解題,該方法的一個缺點在于每個點可能多次進入隊列,這也直接導致了單個點的多次擴展

其實,這題可以采用原始的BFS方法來做,只是不能再用普通的隊列,而需要使用優先級隊列
通過這題,使我對于寬度優先搜索有了新的認識
普通的BFS之所以能夠找到最小的步數,關鍵在于它是單步擴展的,也就是說它首先羅列出所有在一步之內可以到達的點,然后再羅列所有在兩步之內可以到達的點,類似于"1-1-1...-2-2-2...-3-3-3..."的方式
這題在擴展的時候并非都是一步,所以普通的BFS并不能找出正確的解,例如:
Y B
E T
假如我們以右、下、左、上的順序進行擴展,那么我們將得出結果是3,而事實上只需要2

優先級隊列之所以能夠找出正確解,是因為它保證我們始終從最小步數的點開始擴展

代碼(C++)
 1 /* 0MS */
 2 #include<iostream>
 3 #include<cstdio>
 4 #include<cstring>
 5 #include<queue> /* priority queue */
 6 using namespace std;
 7 
 8 #define MAX_LEN 301
 9 #define is_valid(x, y) ((x)>=0 && (x)<M && (y)>=0 && (y)<N)
10 char map[MAX_LEN][MAX_LEN];
11 const int dx[] = {00-11};
12 const int dy[] = {-1100};
13 int M, N;
14 int you_x, you_y, target_x, target_y;
15 int visited[MAX_LEN][MAX_LEN];
16 struct Node {
17     int x, y;
18     int steps;
19     bool operator<(const Node &item) const {
20         return steps > item.steps;
21     }
22 }cur, next;
23 priority_queue<Node> states;
24 
25 int
26 bfs()
27 {
28     int i;
29     memset(visited, 0sizeof(visited));
30     while(!states.empty()) /* empty the queue */
31         states.pop();
32     next.x = you_x;
33     next.y = you_y;
34     next.steps = 0;
35     visited[you_x][you_y] = 1;
36     states.push(next);
37     while(!states.empty()) {
38         cur = states.top();
39         states.pop();
40         if(cur.x==target_x && cur.y==target_y)
41             return cur.steps;
42         for(i=0; i<4; i++) {
43             next.x = cur.x + dx[i];
44             next.y = cur.y + dy[i];
45             if(!visited[next.x][next.y]) {
46                 visited[next.x][next.y] = 1;
47                 if(map[next.x][next.y]=='E' || map[next.x][next.y]=='T') {
48                     next.steps = cur.steps+1;
49                     states.push(next);
50                 } else if(map[next.x][next.y]=='B') {
51                     next.steps = cur.steps+2;
52                     states.push(next);
53                 }
54             }
55         }
56     }
57     return -1;
58 }
59 
60 int
61 main(int argc, char **argv)
62 {
63     int i, j;
64     while(scanf("%d %d"&M, &N)!=EOF && M && N) {
65         for(i=0; i<M; i++) {
66             scanf("%s", map[i]);
67             for(j=0; j<N; j++) {
68                 if(map[i][j] == 'Y') {
69                     you_x = i;
70                     you_y = j;
71                 } else if(map[i][j] == 'T') {
72                     target_x = i; 
73                     target_y = j;
74                 }
75             }
76         }
77         printf("%d\n", bfs());
78     }
79 }

posted on 2010-10-23 20:10 simplyzhao 閱讀(204) 評論(0)  編輯 收藏 引用 所屬分類: B_搜索

導航

<2010年9月>
2930311234
567891011
12131415161718
19202122232425
262728293012
3456789

統計

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一区二区久久久久| 亚洲国产精品久久| 狠狠久久综合婷婷不卡| 亚洲四色影视在线观看| 亚洲精品久久久久久久久| 欧美网站在线观看| 亚洲欧美日韩精品久久亚洲区| 中文高清一区| 亚洲成人自拍视频| 亚洲美女在线看| 韩日欧美一区二区| 亚洲午夜羞羞片| 国产欧美一区二区精品婷婷| 亚洲国产91| 亚洲欧美亚洲| 日韩视频免费观看| 欧美在线影院| 亚洲在线视频| 欧美大片在线看| 欧美伊人精品成人久久综合97| 久久亚洲视频| 午夜一区不卡| 欧美日韩一卡二卡| 亚洲经典三级| 亚洲欧美激情在线视频| 亚洲精品久久久久久下一站| 一区二区三区高清| 99精品视频免费| 美玉足脚交一区二区三区图片| 久久精品一区二区三区不卡牛牛| 欧美日韩国产成人在线91| 亚洲第一精品影视| 亚洲欧洲在线看| 久久婷婷av| 欧美成熟视频| 亚洲国产精品一区二区三区| 玖玖综合伊人| 亚洲欧洲一区二区在线观看| 亚洲人成在线影院| 欧美日韩国产一区| 在线一区免费观看| 欧美一区久久| 在线精品高清中文字幕| 欧美激情久久久久| 亚洲一区二区三区在线播放| 久久精品在线观看| 亚洲三级免费观看| 欧美午夜精品理论片a级按摩| 亚洲视频自拍偷拍| 免费看成人av| 亚洲欧美在线播放| 在线看日韩欧美| 欧美日本一区| 欧美一区成人| 亚洲欧洲在线看| 久久久久久久网站| 亚洲一区在线免费| 亚洲国产精品一区二区第四页av | 欧美成人午夜| 亚洲一区3d动漫同人无遮挡| 国内精品久久久久久影视8| 欧美岛国在线观看| 欧美一级专区| 亚洲女女女同性video| 亚洲国产天堂久久综合| 久久精品99| 欧美一级片在线播放| 日韩视频亚洲视频| 亚洲国产老妈| 一区免费观看| 国产亚洲精品7777| 国产麻豆成人精品| 国产精品青草久久| 国产精品高潮呻吟久久av无限| 欧美激情久久久久| 欧美日本一区二区视频在线观看| 久久综合伊人77777尤物| 久久在线视频在线| 久久亚洲综合网| 免费黄网站欧美| 欧美日韩亚洲免费| 国产欧美一区二区三区久久| 国产精品一二三四| 伊人狠狠色j香婷婷综合| 99国产麻豆精品| 亚洲一区二区在线看| 亚洲欧美国产三级| 久久精品网址| 亚洲成人自拍视频| 亚洲视频一区在线| 午夜精品美女自拍福到在线| 久久精品人人做人人爽电影蜜月| 鲁大师影院一区二区三区| 欧美日韩另类视频| 国产欧美日韩综合一区在线观看 | 欧美在线一区二区| 久久婷婷影院| 日韩视频在线永久播放| 午夜久久久久| 欧美激情精品久久久六区热门| 欧美午夜大胆人体| 亚洲三级影院| 国产精品区一区二区三区| 免费在线国产精品| 韩国精品在线观看| 亚洲欧美精品在线| 亚洲国产裸拍裸体视频在线观看乱了中文 | 久久天天狠狠| 国模一区二区三区| 亚洲欧美日韩综合国产aⅴ| 美日韩精品免费观看视频| 亚洲午夜一级| 欧美日韩中文字幕在线视频| 亚洲精品在线观看免费| 欧美成人综合在线| 免费精品99久久国产综合精品| 精品成人一区二区三区| 久久国产婷婷国产香蕉| 亚洲天堂视频在线观看| 国产精品国产三级国产a| 亚洲视频第一页| 亚洲视频精选在线| 国产精品毛片a∨一区二区三区| 夜夜爽av福利精品导航| 一本大道久久a久久综合婷婷 | 久久亚洲精品一区二区| 欧美在线视频导航| 一区在线视频| 99在线精品视频在线观看| 国产精品久久久久久一区二区三区| 亚洲视频在线二区| 欧美一级艳片视频免费观看| 国产一区二区欧美日韩| 欧美大胆成人| 国产精品一区二区久久| 蜜桃久久精品乱码一区二区| 欧美激情在线播放| 亚洲欧美视频| 欧美精品videossex性护士| 午夜在线不卡| 欧美大片一区二区三区| 欧美主播一区二区三区美女 久久精品人 | 亚洲成人资源网| 国产啪精品视频| 最新高清无码专区| 国产一区二区主播在线| 99国产精品久久久久久久成人热| 国产视频综合在线| 夜夜嗨av一区二区三区免费区| 伊人影院久久| 欧美一级久久| 久久精品日韩欧美| 国产精品视频久久| 99人久久精品视频最新地址| 最新日韩在线视频| 麻豆国产精品va在线观看不卡| 久久狠狠亚洲综合| 国产乱理伦片在线观看夜一区| 91久久国产综合久久91精品网站| 伊人婷婷欧美激情| 久久亚洲国产精品一区二区 | 欧美国产三区| 亚洲黄色在线看| 麻豆精品视频| 日韩视频免费看| 一区二区三区日韩在线观看| 欧美日韩国产成人在线免费 | 一本到高清视频免费精品| 欧美国产另类| 一本色道久久综合狠狠躁篇的优点 | 国产一区二区三区免费观看| 亚洲欧美视频在线| 蜜桃av一区二区三区| 99re这里只有精品6| 国产精品久久久久久久app| 午夜久久黄色| 日韩亚洲一区在线播放| 香蕉国产精品偷在线观看不卡| 国产欧美二区| 欧美日韩国产精品自在自线| 亚洲一区二区三区免费在线观看| 欧美一区免费| 亚洲网站啪啪| 亚洲激情视频在线观看| 国产女同一区二区| 欧美日韩久久久久久| 久久精品日韩| 亚洲综合精品四区| 亚洲美女在线观看| 欧美成人乱码一区二区三区| 午夜精品影院| 一区二区三区视频免费在线观看| 黄色成人在线网址| 国产欧美日韩激情| 国产精品国产一区二区| 欧美日本韩国| 欧美剧在线免费观看网站| 美日韩精品免费观看视频| 欧美在线免费观看| 欧美中在线观看|