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

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)自己對(duì)于復(fù)雜問題的coding能力比較弱,不能很好的理清其中的邏輯關(guān)系,需要多多鍛煉

這題的關(guān)鍵是抓住box的每一次擴(kuò)展,都對(duì)應(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) 評(píng)論(0)  編輯 收藏 引用 所屬分類: B_搜索

導(dǎo)航

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

統(tǒng)計(jì)

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

搜索

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            午夜一级久久| 韩日视频一区| 久久免费视频网站| 裸体歌舞表演一区二区| 一区二区三区精品久久久| 亚洲欧美精品在线| 亚洲国产日日夜夜| 亚洲午夜羞羞片| 亚洲国产毛片完整版| 亚洲一区二区动漫| 亚洲黄页一区| 久久精品2019中文字幕| 亚洲深夜av| 牛牛影视久久网| 欧美一区二区三区久久精品| 欧美电影美腿模特1979在线看| 欧美在线亚洲在线| 欧美三级视频在线观看| 亚洲高清不卡在线观看| 国产欧美日韩综合| 99国产精品99久久久久久粉嫩| 影音先锋日韩有码| 午夜免费日韩视频| 午夜国产精品影院在线观看| 欧美日韩成人| 亚洲国产精品成人| 亚洲高清在线| 久久在精品线影院精品国产| 久久久久成人网| 国产精品日韩电影| 99在线热播精品免费| 99成人在线| 欧美大片免费观看在线观看网站推荐| 久久深夜福利免费观看| 国产欧美一区二区精品婷婷 | 欧美xx视频| 国产亚洲欧美aaaa| 亚洲欧美日韩另类| 久久国产乱子精品免费女 | 一本一本久久| 一区二区国产在线观看| 欧美福利电影网| 亚洲高清成人| 日韩视频精品在线观看| 欧美激情综合| 亚洲剧情一区二区| 亚洲午夜久久久久久尤物| 欧美精品在线观看| 日韩亚洲一区二区| 午夜精品在线看| 国产欧美一区二区精品婷婷 | 欧美精品色综合| 亚洲欧洲精品一区二区精品久久久 | 亚洲在线视频| 久久不射网站| 国产亚洲免费的视频看| 久久精品人人做人人爽电影蜜月| 久久久久久自在自线| 精久久久久久| 欧美成人xxx| 一本久久综合亚洲鲁鲁| 亚洲欧美综合精品久久成人 | 国产一区在线播放| 久久精品二区亚洲w码| 免费成人激情视频| 日韩亚洲欧美一区| 国产精品国产a级| 欧美一级欧美一级在线播放| 久久综合九色综合欧美就去吻 | 亚洲精选一区| 欧美性猛交99久久久久99按摩| 亚洲一区视频在线| 久久精品国内一区二区三区| 亚洲福利一区| 欧美午夜一区二区| 久久精品欧美| 亚洲美女91| 久久嫩草精品久久久精品| 亚洲美女在线看| 国产日韩欧美| 欧美aa在线视频| 亚洲欧美在线另类| 亚洲国产精品高清久久久| 亚洲免费在线观看| 在线欧美影院| 欧美性事在线| 久久资源在线| 亚洲午夜激情网站| 欧美激情亚洲激情| 欧美一区二区三区的| 亚洲精品午夜| 国产一区二区三区四区五区美女| 欧美啪啪一区| 久久一区亚洲| 午夜精品一区二区三区在线视| 亚洲国产精品久久| 久久久久久久一区二区三区| 一区二区三区国产在线| 亚洲成人中文| 国产一区二区0| 欧美性片在线观看| 欧美华人在线视频| 久久久不卡网国产精品一区| 亚洲午夜一区二区三区| 亚洲国产视频a| 久久伊人精品天天| 午夜精品久久久久久久99黑人| 亚洲精品一区二区在线| 黄色亚洲大片免费在线观看| 国产精品扒开腿爽爽爽视频| 欧美成人乱码一区二区三区| 久久九九国产精品| 亚洲综合电影| av不卡在线| 亚洲人成啪啪网站| 欧美激情成人在线视频| 久久在线免费观看| 久久精品国产第一区二区三区最新章节 | 99re热精品| 亚洲黄色性网站| 免费视频一区| 久久综合影音| 久久久久久久久久久成人| 欧美一区二区女人| 午夜伦欧美伦电影理论片| 中文欧美日韩| 在线一区二区三区四区| 一本色道久久88综合日韩精品| 亚洲激情二区| 亚洲激情网址| 亚洲精品视频二区| 日韩一级黄色av| 日韩午夜视频在线观看| 亚洲精品日本| 日韩一级二级三级| 国产精品99久久久久久久久久久久| 亚洲精品中文字| 99视频有精品| 一本色道久久综合亚洲精品小说| 99热免费精品在线观看| 99国产精品久久| 一本大道久久精品懂色aⅴ| 99精品视频免费在线观看| 亚洲视频观看| 小嫩嫩精品导航| 久久看片网站| 欧美黑人国产人伦爽爽爽| 亚洲国产精品精华液2区45| 亚洲精品视频在线| 亚洲午夜黄色| 欧美专区在线播放| 免费欧美日韩| 欧美日韩第一区| 国产精品欧美一区二区三区奶水 | 久久国产夜色精品鲁鲁99| 久久久久久91香蕉国产| 欧美大胆成人| 亚洲狼人综合| 午夜综合激情| 久久综合九九| 欧美日韩一区二区免费在线观看 | 国产午夜亚洲精品理论片色戒| 激情偷拍久久| 亚洲美女在线一区| 亚洲女同精品视频| 另类国产ts人妖高潮视频| 欧美激情一区二区| 一级日韩一区在线观看| 欧美一区在线看| 欧美国产日韩视频| 国产精品任我爽爆在线播放| 在线 亚洲欧美在线综合一区| 亚洲精品一区二区在线| 午夜久久99| 亚洲电影有码| 亚洲欧美日韩成人高清在线一区| 久久久久久伊人| 国产精品免费福利| 在线观看视频一区二区欧美日韩| 一区二区成人精品| 久久亚洲综合网| 一区二区高清在线| 免费观看30秒视频久久| 国产精品成人观看视频国产奇米| 黄色成人精品网站| 亚洲女同在线| 亚洲国产一区二区三区a毛片| 欧美一级网站| 欧美日韩视频| 最新中文字幕亚洲| 久久久成人网| 亚洲一二三四区| 欧美精品v日韩精品v韩国精品v| 国产亚洲精品aa| 亚洲深夜福利| 亚洲片在线资源| 久久躁狠狠躁夜夜爽| 国产亚洲女人久久久久毛片| 亚洲制服丝袜在线| 91久久综合亚洲鲁鲁五月天|