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

隨筆 - 97, 文章 - 22, 評論 - 81, 引用 - 0
數據加載中……

Pku 3346 Treasure of the Chimp Island (Bfs)

去年做杭州網賽的時候遇到的題目,當時一點思路都沒有,過后一直沒去做,今天看了一下,發現其實和hdu的1044很像,可以先縮圖,然后bfs,我用了兩次bfs實現。具體思路是對于每一個非墻非走廊的點進行bfs,擴展和它相鄰的非墻非走廊的點,保存到鄰接表中,然后對于所有邊界上是gate的點進行bfs,用優先隊列實現,狀態為三維,即坐標+內力,其實可以將每個點離散化到一個數字,以減少內存開銷來換取時間。

代碼如下:
#include <iostream>
#include 
<vector>
#include 
<queue>
using namespace std;

int dir[4][2= {{01}{0-1}{10}{-10}};
struct point {
    
int x;
    
int y;
    
int num;
    
int step;
    
bool friend operator < (point a, point b) {
        
return a.step > b.step;
    }

}
temp, tt;

char map[110][110];
vector 
< point > vec[101][101];
int n, m;
int hash[101][101];
priority_queue 
< point > q;
__int8 visit[
100][100][27];
int ans;

//縮圖
void bfs(int x, int y) {

    
int i;
    temp.x 
= x;
    temp.y 
= y;
    memset(hash, 
0sizeof(hash));
    
while(!q.empty() )
        q.pop();

    q.push( temp );
    hash[ temp.x ][ temp.y ] 
= 1;

    
while(!q.empty()) {

        temp 
= q.top();
        q.pop();
        
for(i = 0; i < 4; i++{
            tt.x 
= temp.x + dir[i][0];
            tt.y 
= temp.y + dir[i][1];

            
if(tt.x < 0 || tt.y < 0 || tt.x == n || tt.y == m)
                
continue;
            
if(map[tt.x][tt.y] == '*'
                
continue;
            
if(map[tt.x][tt.y] >= 'A' && map[tt.x][tt.y] <= 'Z')
                
continue;
            
if(map[tt.x][tt.y] == '#')
                
continue;
            
if(hash[ tt.x ][ tt.y ])
                
continue;

            
if(!hash[ tt.x ][ tt.y ] ) {
                hash[ tt.x ][ tt.y ] 
= 1;

                
if(map[tt.x][tt.y] == '.')
                    q.push( tt );
                
else {
                    vec[x][y].push_back( tt );
                }

            }

        }

    }

}


//求最短距離
int BFS(int x, int y, int num) {

    
int i;
    temp.step 
= 0;
    temp.x 
= x;
    temp.y 
= y;
    temp.num 
= num;

    
while(!q.empty())
        q.pop();

    memset(visit, 
-1sizeof(visit));
    q.push( temp );

    visit[ temp.x ][ temp.y ][ temp.num ] 
= 0;

    
while!q.empty() ) {
        temp 
= q.top();
        q.pop();

        
if(temp.step > ans && ans != -1)
            
return -1;

        
if( map[ temp.x ][ temp.y ] == '$')
            
return temp.step;

        
int size = vec[ temp.x ][ temp.y ].size();

        
for(i = 0; i < size; i++{
            point rt 
= vec[ temp.x ][ temp.y ][ i ];

            
if(map[rt.x][rt.y] == '$'{
                tt.num 
= temp.num;
                tt.step 
= temp.step;

                tt.x 
= rt.x;
                tt.y 
= rt.y;
                
if(tt.step < visit[ tt.x ][ tt.y ][ tt.num ]
                    
|| visit[ tt.x ][ tt.y ][ tt.num ] == -1{
                    visit[ tt.x ][ tt.y ][ tt.num ] 
= tt.step;
                    q.push( tt );
                }

                
continue;
            }


            
if(temp.num) {
                tt.num 
= temp.num - 1;
                tt.step 
= temp.step;
                tt.x 
= rt.x;
                tt.y 
= rt.y;
                
if(tt.step < visit[ tt.x ][ tt.y ][ tt.num ]
                    
|| visit[ tt.x ][ tt.y ][ tt.num ] == -1{
                    visit[ tt.x ][ tt.y ][ tt.num ] 
= tt.step;
                    q.push( tt );
                }

            }


            tt.num 
= temp.num;
            tt.step 
= temp.step + map[rt.x][rt.y] - '0';
            tt.x 
= rt.x;
            tt.y 
= rt.y;

            
if(tt.step < visit[ tt.x ][ tt.y ][ tt.num ]
                
|| visit[ tt.x ][ tt.y ][ tt.num ] == -1{
                visit[ tt.x ][ tt.y ][ tt.num ] 
= tt.step;
                q.push( tt );
            }

        }

    }


    
return -1;
}


int main() {

    
int i, j;
    
while(1{

        
while(gets(map[0])) {
            
if( strcmp(map[0], "") )
                
break;
        }
        
        m 
= strlen( map[0] );

        
if(strcmp(map[0], "--"== 0)
            
break;

        n 
= 1;
        
while(gets(map[n])) {
            
if(strcmp( map[n], "" ) == 0)
                
break;
            
else
                n 
++;
        }


        
for(i = 0; i < n; i++{
            
for(j = 0;j < m; j++)
                vec[i][j].clear();
        }


        
for(i = 0; i < n; i++{

            
for(j = 0; j < m; j++{

                
if(map[i][j] >= '1' && map[i][j] <= '9'{
                    bfs(i, j);
                }


                
if(map[i][j] >= 'A' && map[i][j] <= 'Z' || map[i][j] == '#'{
                    bfs(i, j);
                }

            }

        }


        ans 
= -1;
        
        
for(i = 0; i < n; i++{

            
for(j = 0; j < m; j++{

                
if(map[i][j] >= 'A' && map[i][j] <= 'Z'{
                    
int ty = BFS(i, j, map[i][j]-'A'+1);
                    
if(ty != -1{
                        
if(ty < ans || ans == -1)
                            ans 
= ty;
                    }

                }

                
if(map[i][j] == '#'{
                    
int ty = BFS(i, j, 0);    
                    
if(ty != -1{
                        
if(ty < ans || ans == -1)
                            ans 
= ty;
                    }

                }

            }

        }


        
if(ans == -1)
            printf(
"IMPOSSIBLE\n");
        
else
            printf(
"%d\n", ans);

    }

    
return 0;
}

posted on 2009-03-10 08:20 英雄哪里出來 閱讀(440) 評論(0)  編輯 收藏 引用 所屬分類: ACM

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产欧美一区二区三区在线看蜜臀| 亚洲国产一区二区三区在线播 | 在线亚洲一区| 日韩午夜电影在线观看| 亚洲一区二区三区免费视频| 久久精品论坛| 欧美日韩的一区二区| 国产精品视频免费观看| 一区视频在线播放| 艳妇臀荡乳欲伦亚洲一区| 午夜一区不卡| 亚洲高清色综合| 欧美亚洲系列| 欧美日韩亚洲一区二区三区四区| 国产又爽又黄的激情精品视频| 一本大道久久精品懂色aⅴ| 亚洲日本乱码在线观看| 久久精品人人做人人爽| 亚洲高清网站| 欧美在线日韩精品| av成人黄色| 久久久久久一区二区三区| 国产精品高潮呻吟久久av无限 | 国产色综合天天综合网| 一区二区91| 欧美一区二区三区精品电影| 亚洲国产你懂的| 久久久久久一区| 亚洲无线观看| 欧美午夜激情视频| 一本久道综合久久精品| 午夜久久久久久| 国产乱码精品一区二区三区av | 好吊色欧美一区二区三区四区| 亚洲欧美国产不卡| 亚洲精品久久7777| 国内外成人在线视频| 99爱精品视频| 亚洲国产片色| 欧美一区影院| 激情久久五月天| 在线一区二区三区做爰视频网站| 亚洲国产成人在线视频| 亚洲欧美日韩精品久久奇米色影视 | 亚洲永久精品国产| 日韩一级精品| 亚洲人成高清| 亚洲精品一级| 国产精品每日更新| 欧美一区二区免费观在线| 亚洲一区在线观看视频| 亚洲国产精品电影在线观看| 性色av一区二区三区在线观看| 一个人看的www久久| 免费视频一区| 日韩一区二区精品| 亚洲最新在线视频| 亚洲免费大片| 亚洲一区精品电影| 亚洲视频国产视频| 亚洲欧美日韩在线高清直播| 欧美日韩在线观看一区二区三区| 欧美精品一区二区三区高清aⅴ| 欧美第十八页| 一本一本久久| 欧美激情1区| 欧美在线精品一区| 国产乱人伦精品一区二区| 99伊人成综合| 亚洲综合99| 国产精品狠色婷| 一本色道久久加勒比精品| 国产亚洲欧美一区二区| 欧美激情无毛| 欧美视频中文字幕| 久久久久久有精品国产| 国产主播喷水一区二区| 欧美在线免费看| 蜜桃av一区二区三区| 欧美二区视频| 亚洲欧洲精品一区二区三区波多野1战4 | 欧美精品性视频| 久久美女性网| 在线观看一区视频| 亚洲欧美激情四射在线日 | 中文一区二区| 国产精品国产自产拍高清av| 亚洲一二三区在线观看| 久久精品国产综合| 欧美精品成人| 一区二区三区产品免费精品久久75| 亚洲自拍电影| 国内在线观看一区二区三区| 男女激情久久| 亚洲视频免费在线观看| 麻豆精品国产91久久久久久| 国产精品国产成人国产三级| 羞羞色国产精品| 欧美黄免费看| 亚欧成人精品| 91久久精品日日躁夜夜躁国产| 欧美日韩综合一区| 久久激五月天综合精品| 欧美一区二区三区视频免费播放 | 嫩草国产精品入口| 亚洲视频一起| 你懂的成人av| 在线精品视频一区二区| 欧美日韩午夜| 久久精品国产久精国产爱| 亚洲国产综合在线| 久久精品国产亚洲精品| 一本色道88久久加勒比精品| 国产片一区二区| 欧美日韩1234| 久久免费视频一区| 欧美 亚欧 日韩视频在线| 亚洲一区二区三区免费在线观看| 欧美精品久久久久久久| 久久成年人视频| 在线视频中文亚洲| 亚洲欧洲日产国产网站| 免费成人av| 久久av在线看| 性亚洲最疯狂xxxx高清| 一二三四社区欧美黄| 亚洲精品一区二区在线观看| 欧美激情精品久久久久久蜜臀| 欧美一区二区三区四区夜夜大片| 99精品欧美一区二区三区综合在线| 麻豆成人在线观看| 久久一区二区三区国产精品| 黄色日韩网站| 国产偷自视频区视频一区二区| 国产精品福利久久久| 欧美国产免费| 欧美福利一区二区三区| 免费人成精品欧美精品| 美女在线一区二区| 亚洲伦理一区| 亚洲精品乱码久久久久| 欧美激情视频网站| 亚洲成人在线视频播放| 亚洲无限av看| 亚洲网友自拍| 午夜精品福利电影| 黄色av一区| 精久久久久久久久久久| 禁断一区二区三区在线| 在线精品观看| 亚洲欧洲精品天堂一级| 亚洲区中文字幕| 99国产精品一区| 亚洲午夜在线观看视频在线| 亚洲一区在线视频| 午夜国产精品视频| 久久精品视频播放| 久久亚洲捆绑美女| 欧美第十八页| 久久精品99国产精品| 久久精品最新地址| 亚洲在线视频| 欧美一区国产二区| 另类综合日韩欧美亚洲| 欧美岛国在线观看| 日韩视频在线你懂得| 夜夜精品视频一区二区| 欧美一区二粉嫩精品国产一线天| 久久国产精品色婷婷| 欧美v亚洲v综合ⅴ国产v| 欧美另类69精品久久久久9999| 欧美午夜激情视频| 国内一区二区三区| 日韩视频精品在线观看| 午夜精品久久久久久久99樱桃| 久久手机精品视频| 亚洲日本一区二区| 小黄鸭精品aⅴ导航网站入口| 另类春色校园亚洲| 久久久精品网| 欧美日韩免费一区| 国产亚洲精品一区二555| 亚洲国产日日夜夜| 欧美亚洲网站| 欧美激情一区二区三区四区| 亚洲无限乱码一二三四麻| 榴莲视频成人在线观看| 国产精品久久久久久久久搜平片 | 欧美黄污视频| 亚洲免费影院| 欧美久久婷婷综合色| 国产一区二区三区免费观看| 99在线精品视频| 久久婷婷影院| 亚洲一区二区免费看| 欧美激情一区二区在线| 国产一区二区高清| 亚洲男人第一av网站| 亚洲激情网站免费观看| 久久九九热免费视频|