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

            學習心得(code)

            superlong@CoreCoder

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

            公告

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

            常用鏈接

            留言簿(4)

            我參與的團隊

            搜索

            •  

            最新隨筆

            最新評論

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

            閱讀排行榜

            評論排行榜

            搜索,把所有能走的點映射一下(這些點不多,最多100多個),狀態就是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 閱讀(88) 評論(0)  編輯 收藏 引用
            久久精品国产影库免费看| 亚洲狠狠综合久久| 久久久久青草线蕉综合超碰| 中文无码久久精品| 国产一区二区三区久久| 国产精品青草久久久久福利99| 欧美日韩精品久久久免费观看| 久久婷婷五月综合97色 | 亚洲精品乱码久久久久66| 精品国产乱码久久久久久郑州公司| 精品久久久久久国产牛牛app| 精品无码久久久久国产动漫3d| 久久精品男人影院| 婷婷五月深深久久精品| 久久久久一级精品亚洲国产成人综合AV区| A级毛片无码久久精品免费| 久久精品嫩草影院| 久久精品国产亚洲av高清漫画 | 久久w5ww成w人免费| 婷婷国产天堂久久综合五月| 久久综合中文字幕| 久久精品蜜芽亚洲国产AV| 国产亚洲美女精品久久久2020| 久久精品免费网站网| 99久久精品国产一区二区蜜芽| 久久无码人妻一区二区三区| 国产aⅴ激情无码久久| 久久伊人五月丁香狠狠色| 亚洲国产成人久久综合野外| 久久亚洲精品无码播放| 精品久久久久中文字| 国产精自产拍久久久久久蜜| 色噜噜狠狠先锋影音久久| 99久久久精品| 情人伊人久久综合亚洲| 青青草原1769久久免费播放 | 人妻无码精品久久亚瑟影视| 94久久国产乱子伦精品免费| 国产日韩久久免费影院| 久久99久久成人免费播放| 久久影院午夜理论片无码|