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

A Za, A Za, Fighting...

堅(jiān)信:勤能補(bǔ)拙

PKU 1475 Pushing Boxes

問題:
http://acm.pku.edu.cn/JudgeOnline/problem?id=1475

思路:
很復(fù)雜的一題,從discuss知道可以采用嵌套的BFS來做,不過始終不知道如何下手
通過這題,發(fā)現(xiàn)自己對于復(fù)雜問題的coding能力比較弱,不能很好的理清其中的邏輯關(guān)系,需要多多鍛煉

這題的關(guān)鍵是抓住box的每一次擴(kuò)展,都對應(yīng)地存在一個(gè)person的起始位置,兩者需要同時(shí)記錄

參考:
http://www.chhaya.me/?p=147

代碼:
  1 #include<stdio.h>
  2 #include<stdlib.h>
  3 #include<string.h>
  4 #define MAX_LEN 21
  5 /* north, south, east, west */
  6 const int dx[] = {-1100};
  7 const int dy[] = {001-1};
  8 const char dir_box[] = "NSEW";
  9 const char dir_psn[] = "nsew";
 10 int r, c;
 11 int px, py, bx, by, btx, bty;
 12 char map[MAX_LEN][MAX_LEN];
 13 struct EACH {
 14     int x, y;
 15     int id;
 16     int pre;
 17     int dir;
 18 };
 19 struct EACH cur_each, tmp_each, cur_psn, tmp_psn, box_queue[MAX_LEN*MAX_LEN], psn_queue[MAX_LEN*MAX_LEN];
 20 struct {
 21     int x, y;
 22 }persons[MAX_LEN*MAX_LEN];
 23 int visited_box[MAX_LEN][MAX_LEN];
 24 int visited_psn[MAX_LEN][MAX_LEN];
 25 int cnt[MAX_LEN*MAX_LEN];
 26 char seq[MAX_LEN*MAX_LEN][MAX_LEN*MAX_LEN];
 27 
 28 int
 29 is_valid_box(struct EACH item, int dir)
 30 {
 31     int tmpx, tmpy;
 32     if(item.x<0 || item.x>=|| item.y<0 || item.y>=|| map[item.x][item.y]=='#')
 33         return 0;
 34     /* see if there exists a position for person to push */
 35     tmpx = item.x-2*dx[dir];
 36     tmpy = item.y-2*dy[dir];
 37     if(tmpx<0 || tmpx>=|| tmpy<0 || tmpy>=|| map[tmpx][tmpy]=='#')
 38         return 0;
 39     return 1;
 40 }
 41 
 42 int
 43 is_valid_psn(int psnx, int psny, int boxx, int boxy)
 44 {
 45     if(psnx<0 || psnx>=|| psny<0 || psny>=|| map[psnx][psny]=='#')
 46         return 0;
 47     /* path of person can't cover the box */
 48     if(psnx==boxx && psny==boxy)
 49         return 0;
 50     return 1;
 51 }
 52 
 53 int
 54 psn_bfs(int startx, int starty, int endx, int endy, int dir, int index)
 55 {
 56     int i, head, tail;
 57     struct EACH tmp;
 58     memset(visited_psn, 0sizeof(visited_psn));
 59     head = -1;
 60     tail = 0;
 61     psn_queue[tail].x = startx;
 62     psn_queue[tail].y = starty;
 63     psn_queue[tail].pre = -1;
 64     visited_psn[startx][starty] = 1;
 65     while(head < tail) {
 66         ++head;
 67         cur_psn = psn_queue[head];
 68         if(cur_psn.x==endx && cur_psn.y==endy) {
 69             /* record */
 70             /* here 'index' should plus 1, according to box_bfs */
 71             persons[index+1].x = cur_psn.x + dx[dir];
 72             persons[index+1].y = cur_psn.y + dy[dir];
 73             cnt[index+1= 0;
 74             tmp = cur_psn;
 75             while(tmp.pre != -1) {
 76                 seq[index+1][cnt[index+1]++= dir_psn[tmp.dir];
 77                 tmp = psn_queue[tmp.pre];
 78             }
 79             return 1;
 80         }
 81         for(i=0; i<4; i++) {
 82             tmp_psn.x = cur_psn.x + dx[i];
 83             tmp_psn.y = cur_psn.y + dy[i];
 84             if(is_valid_psn(tmp_psn.x, tmp_psn.y, endx+dx[dir], endy+dy[dir]) && !visited_psn[tmp_psn.x][tmp_psn.y]) {
 85                 ++tail;
 86                 tmp_psn.pre = head;
 87                 tmp_psn.dir = i;
 88                 psn_queue[tail] = tmp_psn;
 89                 visited_psn[tmp_psn.x][tmp_psn.y] = 1;
 90             }
 91         }
 92     }
 93     return 0;
 94 }
 95 
 96 void
 97 output(struct EACH *end)
 98 {
 99     int i, index;
100     if(end->pre == -1)
101         return;
102     output(box_queue+(end->pre));
103     index = end->id;
104     for(i=cnt[index]-1; i>=0; i--)
105         printf("%c", seq[index][i]);
106     printf("%c", dir_box[end->dir]);
107 }
108 
109 void
110 box_bfs()
111 {
112     int i, psn_rt, head, tail;
113     head = -1;
114     tail = 0;
115     memset(visited_box, 0sizeof(visited_box));
116     box_queue[tail].x = bx;
117     box_queue[tail].y = by;
118     box_queue[tail].pre = -1;
119     box_queue[tail].id = tail;
120     visited_box[bx][by] = 1;
121     persons[tail].x = px;
122     persons[tail].y = py;
123     while(head < tail) {
124         ++head;
125         cur_each = box_queue[head];
126         if(cur_each.x==btx && cur_each.y==bty) {
127             /* output */
128             output(box_queue+head);
129             return;
130         }
131         for(i=0; i<4; i++) {
132             tmp_each.x = cur_each.x + dx[i];
133             tmp_each.y = cur_each.y + dy[i];
134             if(is_valid_box(tmp_each, i) && !visited_box[tmp_each.x][tmp_each.y]) {
135                 /* bfs for person */
136                 psn_rt = psn_bfs(persons[head].x, persons[head].y, tmp_each.x-2*dx[i], tmp_each.y-2*dy[i], i, tail);
137                 if(psn_rt) {
138                     ++tail;
139                     tmp_each.dir = i;
140                     tmp_each.pre = head;
141                     tmp_each.id = tail;
142                     box_queue[tail] = tmp_each;
143                     visited_box[tmp_each.x][tmp_each.y] = 1;
144                 }
145             }
146         }
147     }
148     printf("Impossible.");
149 }
150 
151 int
152 main(int argc, char **argv)
153 {
154     int i, j, tests = 0;
155     while(scanf("%d %d"&r, &c) != EOF) {
156         if(r==0 && c==0)
157             break;
158         for(i=0; i<r; i++) {
159             scanf("%s", map[i]);
160             for(j=0; j<c; j++) {
161                 if(map[i][j] == 'S') {
162                     px = i;
163                     py = j;
164                 } else if(map[i][j] == 'B') {
165                     bx = i;
166                     by = j;
167                 } else if(map[i][j] == 'T') {
168                     btx = i;
169                     bty = j;
170                 }
171             }
172         }
173         printf("Maze #%d\n"++tests);
174         /* bfs */
175         box_bfs();
176         printf("\n\n");
177     }
178 }

posted on 2010-08-05 12:14 simplyzhao 閱讀(288) 評論(0)  編輯 收藏 引用 所屬分類: B_搜索

導(dǎo)航

<2010年8月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
2930311234

統(tǒng)計(jì)

常用鏈接

留言簿(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>
            亚洲在线视频| 亚洲伦伦在线| 久久爱www久久做| 国产亚洲va综合人人澡精品| 欧美国产日本韩| 亚洲免费福利视频| 亚洲毛片在线| 国产精品成人国产乱一区| 亚洲一区二区在线看| 亚洲视频精选在线| 国产日韩精品视频一区二区三区| 久久黄金**| 久久亚洲国产精品一区二区| 亚洲精品一区二区三区婷婷月| 亚洲精品视频中文字幕| 国产精品www| 久久久久成人精品| 另类天堂av| 在线一区欧美| 欧美亚洲免费| 91久久线看在观草草青青| 亚洲麻豆视频| 国产一区视频网站| 亚洲国产导航| 欧美性猛片xxxx免费看久爱| 欧美在线在线| 欧美激情网友自拍| 欧美在线999| 欧美激情中文字幕乱码免费| 性亚洲最疯狂xxxx高清| 久久亚洲影院| 午夜精品视频在线| 久久综合激情| 欧美一二三视频| 欧美精品网站| 美女国内精品自产拍在线播放| 欧美精品一区二区三| 久久久99爱| 欧美日韩在线一二三| 亚洲另类在线视频| 午夜久久资源| 亚洲午夜电影在线观看| 久久久人人人| 久久久精品久久久久| 欧美人交a欧美精品| 久久久久久久久综合| 欧美日一区二区在线观看| 欧美成人网在线| 国产一区在线视频| 亚洲视频你懂的| 99精品热视频| 牛牛国产精品| 欧美成人免费在线观看| 国内精品久久久久久久影视蜜臀| 一区二区三区久久久| 日韩午夜av电影| 老鸭窝毛片一区二区三区 | 欧美jizz19hd性欧美| 午夜免费久久久久| 欧美日韩一区二区在线播放| 亚洲欧美国产日韩天堂区| 欧美成人自拍| 中日韩高清电影网| 欧美福利一区| 亚洲电影免费在线观看| 亚洲国产高清高潮精品美女| 久久精品1区| 久久久人成影片一区二区三区观看| 国产精品美女久久久久久久| 日韩视频精品在线观看| 亚洲精选视频免费看| 蜜桃av综合| 欧美激情一区二区三区在线视频观看| 韩曰欧美视频免费观看| 久久经典综合| 欧美成人午夜免费视在线看片| 一区二区三区我不卡| 美腿丝袜亚洲色图| 欧美国产日韩亚洲一区| 91久久精品国产91久久性色| 蜜臀久久99精品久久久久久9| 欧美jizz19性欧美| 亚洲精品一区二区三区蜜桃久 | 久久国产综合精品| 另类专区欧美制服同性| 狠狠色噜噜狠狠狠狠色吗综合| 欧美一激情一区二区三区| 久久久免费av| 亚洲激情在线激情| 欧美日韩国产成人在线观看| 国产精品99久久久久久久vr| 亚洲欧美国产一区二区三区| 国产亚洲美州欧州综合国| 久久久国产精彩视频美女艺术照福利| 免费观看一区| 在线视频免费在线观看一区二区| 国产精品美女久久久久久2018 | 中文在线资源观看网站视频免费不卡 | 亚洲视频一二三| 国产精品视频免费在线观看| 午夜精品一区二区三区电影天堂| 久久全球大尺度高清视频| 亚洲欧洲日本国产| 国产精品一区2区| 免费日韩av电影| 亚洲视频在线播放| 欧美不卡三区| 亚洲欧美日产图| 91久久综合亚洲鲁鲁五月天| 国产精品国产三级国产aⅴ无密码| 欧美在线播放一区| 亚洲国产国产亚洲一二三| 亚洲欧美国产高清| 亚洲成人在线视频播放| 国产精品h在线观看| 麻豆久久婷婷| 先锋影音久久久| 99精品欧美一区二区三区综合在线| 久久久久久久综合色一本| 99精品视频一区二区三区| 国产亚洲精品美女| 国产精品久久久久久久7电影| 美女露胸一区二区三区| 香港成人在线视频| 夜夜爽夜夜爽精品视频| 亚洲成色最大综合在线| 国产中文一区二区| 欧美日韩在线播放一区| 久久中文精品| 欧美一区二区三区免费在线看| 99热免费精品| 亚洲精品之草原avav久久| 免费看av成人| 免费成人小视频| 久久亚洲国产精品一区二区| 亚洲欧美在线免费观看| 一区二区三区视频在线播放| 亚洲国产另类精品专区| 国产一区二区三区免费观看| 国产精品日韩一区二区三区| 国产精品久久久久77777| 欧美色播在线播放| 欧美喷潮久久久xxxxx| 欧美成人自拍| 欧美精品一区二区三区视频| 欧美精品久久久久久久免费观看| 猛男gaygay欧美视频| 久久亚洲视频| 免费欧美网站| 免费观看亚洲视频大全| 免费在线看成人av| 欧美a级大片| 欧美老女人xx| 国产精品白丝黑袜喷水久久久| 欧美色欧美亚洲另类七区| 欧美色123| 国产精品亚洲精品| 国产亚洲欧美一区二区| 黄色亚洲免费| 最新国产成人av网站网址麻豆| 亚洲国产婷婷香蕉久久久久久99| **性色生活片久久毛片| 亚洲国产另类 国产精品国产免费| 91久久精品国产91久久性色tv| 亚洲另类春色国产| 亚洲永久免费av| 久久成人av少妇免费| 免费观看成人| 亚洲精品网址在线观看| 亚洲深夜福利视频| 欧美亚洲一区| 你懂的亚洲视频| 欧美午夜精品一区二区三区| 国产老女人精品毛片久久| 好看的亚洲午夜视频在线| 亚洲精品一区中文| 亚洲一级高清| 久久青草欧美一区二区三区| 欧美寡妇偷汉性猛交| 正在播放亚洲一区| 久久精品夜色噜噜亚洲aⅴ| 欧美成人精品在线| 国产精品乱码久久久久久| 激情婷婷亚洲| 亚洲一区二区三区三| 久久婷婷麻豆| 亚洲视频1区| 免费不卡在线观看| 国产精品专区h在线观看| 亚洲第一伊人| 欧美一级理论性理论a| 亚洲福利一区| 欧美淫片网站| 国产精品久在线观看| 亚洲级视频在线观看免费1级| 午夜国产精品视频免费体验区| 免费在线成人av| 午夜精品久久久久久99热软件 | 亚洲小视频在线| 欧美大秀在线观看|