• <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>

            學(xué)習(xí)心得(code)

            superlong@CoreCoder

              C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              74 Posts :: 0 Stories :: 5 Comments :: 0 Trackbacks

            公告

            文字可能放在http://blog.csdn.net/superlong100,此處存放代碼

            常用鏈接

            留言簿(4)

            我參與的團(tuán)隊(duì)

            搜索

            •  

            最新隨筆

            最新評論

            • 1.?re: Poj 1279
            • 對于一個(gè)凹多邊形用叉積計(jì)算面積 后能根據(jù)結(jié)果的正負(fù)來判斷給的點(diǎn)集的時(shí)針方向?
            • --bsshanghai
            • 2.?re: Poj 3691
            • 你寫的這個(gè)get_fail() 好像并是真正的get_fail,也是說fail指向的串并不是當(dāng)前結(jié)點(diǎn)的子串。為什么要這樣弄呢?
            • --acmer1183
            • 3.?re: HDU2295[未登錄]
            • 這個(gè)是IDA* 也就是迭代加深@ylfdrib
            • --superlong
            • 4.?re: HDU2295
            • 評論內(nèi)容較長,點(diǎn)擊標(biāo)題查看
            • --ylfdrib
            • 5.?re: HOJ 11482
            • 呵呵..把代碼發(fā)在這里很不錯(cuò)..以后我也試試...百度的編輯器太爛了....
            • --csuft1

            閱讀排行榜

            評論排行榜

            搜索,把所有能走的點(diǎn)映射一下(這些點(diǎn)不多,最多100多個(gè)),狀態(tài)就是100*100*100的

            #include <stdio.h>
            #include 
            <string.h>

            const int N = 55;
            const int M = 105;

            int n, m;
            char str[N][N];
            int map[N][N];
            int Xend[M], numB, numX;
            int dic[M][5];
            int len[M];
            int move[4][2= {{0 , 1}, {0-1}, {10}, {-10}};
            bool h[M][M][M];
            int flagB, flagX;

            struct node {
                
            int me, b1, b2;
                
            void write() {
                    printf(
            "%d %d %d\n", me, b1, b2);
                }
            };

            inline 
            bool ok (int i, int j) {
                
            if( i < 0 || i >= n || j < 0 || j >= m ) return false;
                
            if( str[i][j] == '#'return false;
                
            return true;
            }

            void read() {
                scanf(
            "%d %d"&n, &m);
                
            for(int i = 0; i < n; i ++) {
                    scanf(
            "%s", str[i]);
                }
            }

            int close, open, cnt;
            int f, e, b[2];
            node que[
            1000001];

            void pre() {
                
            int tp = 1;
                cnt 
            = 1;
                memset(map, 
            0sizeof(map));
                memset(Xend, 
            0sizeof(Xend));
                close 
            = -1; open = 0;
                que[
            0].me = que[0].b1 = que[0].b2 = 0;
                flagX 
            = flagB = 0;
                b[
            0= b[1= 0;
                numB 
            = 0; numX = 0;
                
            for(int i = 0; i < n; i ++) {
                    
            for(int j = 0; j < m; j ++) {
                        
            if( str[i][j] == '.' ) map[i][j] = cnt++;
                        
            if( str[i][j] == 'S' ) {map[i][j] = cnt; f = cnt++;}
                        
            if( str[i][j] == 'E' ) {map[i][j] = cnt; e = cnt++;}
                        
            if( str[i][j] == 'X' ) {
                            numX 
            ++;
                            flagX 
            = 1;
                            map[i][j] 
            = cnt;
                            
            if( tp == 1)     que[open].b1 = cnt;
                            
            else             que[open].b2 = cnt;
                            cnt 
            ++;
                            tp 
            ++;
                        }
                        
            if( str[i][j] == 'B') {
                            numB 
            ++;
                            flagB 
            = 1;
                            Xend[cnt] 
            = 1;
                            map[i][j] 
            = cnt++;
                        }
                    }
                }
                Xend[
            0= 1;
                que[open].me 
            = f;
            }

            void build() {
                
            for(int i = 0; i < n; i ++) {
                    
            for(int j = 0; j < m; j ++) {
                        
            if( ok(i, j) ) {
                            
            for(int k = 0; k < 4; k ++) {
                                
            if( ok(i+move[k][0], j+move[k][1]) ) {
                                    dic[map[i][j]][k] 
            = map[i+move[k][0]][j+move[k][1]];
                                } 
            else {
                                    dic[map[i][j]][k] 
            = -1;
                                }
                            }
                        }
                    }
                }
            }

            inline 
            bool end(node a) {
                
            if( a.me != e ) return false;
                
            if!flagB ) return true;
                
            if( numX == 1 && Xend[a.b1]  ) return true;
                
            if( Xend[a.b1] && Xend[a.b2] ) return true;
                
            return false;
            }

            bool expand(node now) {
                node next;
                
            for(int i = 0; i < 4; i ++) {
                    next.me 
            = dic[now.me][i];
                    next.b1 
            = now.b1;
                    next.b2 
            = now.b2;
                    
            if( next.me == -1 ) continue;
                    
            if( now.b1 == next.me && dic[now.b1][i] != -1 ) {
                        next.b1 
            = dic[now.b1][i];
                        next.b2 
            = now.b2;
                    } 
            else if( now.b2 == next.me && dic[now.b2][i] != -1 ) {
                        next.b2 
            = dic[now.b2][i];
                        next.b1 
            = now.b1;
                    } 
            else if( now.b1 != next.me && now.b2 != next.me ) {
                        next.b1 
            = now.b1;
                        next.b2 
            = now.b2;
                    } 
            else {
                        
            continue;
                    }
                    
            if( next.b1 == next.b2 && next.b1 != 0 ) continue;
                    
            if( h[next.me][next.b1][next.b2] ) continue;
                    
            if( end(next) ) return true;
                    h[next.me][next.b1][next.b2] 
            = 1;
                    que[
            ++open] = next;
                }
                
            return false;
            }

            int bfs() {
                
            if( flagB && !flagX) return -1;
                
            if( numB > numX ) return -1;
                
            int step = 0, size = 0;
                memset(h, 
            0sizeof(h));
                h[que[
            0].me][que[0].b1][que[0].b2] = 1;
                node now;
                
            while( close < open ) {
                    size 
            = open - close;
                    
            while( size -- ) {
                        now 
            = que[++close];
                        
            if( expand(now) ) {
                            
            return step + 1;
                        }
                    }
                    step 
            ++;
                }
                
            return -1;
            }

            int main() {
                freopen(
            "testdata.in""r", stdin);
                
            int t;
                scanf(
            "%d"&t);
                
            while( t -- ) {
                    read();
                    pre();
                    build();
                    
            int ans = bfs();
                    
            if( ans != -1 )    printf("%d\n", ans);
                    
            else            printf("impossible\n");
                }
                
            while(1);
            }

            posted on 2010-08-01 17:16 superlong 閱讀(85) 評論(0)  編輯 收藏 引用
            国产精品欧美久久久久天天影视| 中文国产成人精品久久亚洲精品AⅤ无码精品| 久久人与动人物a级毛片| 久久人人爽人人爽人人片AV麻烦 | 99久久精品午夜一区二区| 精品久久久久久亚洲| 色综合合久久天天给综看| 久久综合给久久狠狠97色| 国产成人精品久久综合| 久久精品国产99国产精品导航| 久久成人国产精品二三区| 久久精品无码专区免费 | 久久精品国产第一区二区| 久久人人爽人人爽人人片AV高清| 精品永久久福利一区二区| 无码乱码观看精品久久| 久久久久久a亚洲欧洲aⅴ| 伊人久久大香线焦AV综合影院| 国产精品九九久久精品女同亚洲欧美日韩综合区| 久久久久久青草大香综合精品| 日韩精品久久久久久久电影蜜臀| 久久人人爽人人精品视频| 国产精品久久久久影视不卡| 国产激情久久久久久熟女老人| 久久高潮一级毛片免费| 国产精品一区二区久久精品| 99精品国产综合久久久久五月天| 久久青青草原精品国产不卡| 亚洲国产成人久久综合碰碰动漫3d| 人妻精品久久无码区| 久久人人爽人人爽人人爽| 久久九色综合九色99伊人| 国内精品久久久久久久久| 久久99国产精品久久99| 精品久久久久久中文字幕| WWW婷婷AV久久久影片| 久久精品天天中文字幕人妻| 亚洲国产精品无码久久SM| 亚洲人成伊人成综合网久久久| 久久SE精品一区二区| 无码久久精品国产亚洲Av影片|