• <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)  編輯 收藏 引用
            久久久青草青青国产亚洲免观| 久久精品国产亚洲av高清漫画| 久久久久女教师免费一区| 久久久久人妻一区精品果冻| 少妇无套内谢久久久久| WWW婷婷AV久久久影片| 久久精品国产一区二区三区| 成人久久免费网站| 热99re久久国超精品首页| 中文字幕亚洲综合久久菠萝蜜| 久久综合狠狠综合久久综合88| 久久97久久97精品免视看秋霞| 午夜人妻久久久久久久久| 国内精品伊人久久久久网站| 久久w5ww成w人免费| 久久亚洲色一区二区三区| 久久99国产精一区二区三区| 奇米影视7777久久精品人人爽| 91精品国产高清久久久久久国产嫩草 | 久久人人妻人人爽人人爽| 国产精品99久久久久久宅男| 国产69精品久久久久9999APGF| 国内精品久久久久久久coent| 婷婷伊人久久大香线蕉AV| 漂亮人妻被中出中文字幕久久| 国产午夜精品理论片久久| 久久久久夜夜夜精品国产| 97久久国产亚洲精品超碰热| 精品综合久久久久久97| 最新久久免费视频| 久久噜噜久久久精品66| 品成人欧美大片久久国产欧美... 品成人欧美大片久久国产欧美 | 久久国产精品成人免费| 亚洲va中文字幕无码久久不卡 | 久久精品99久久香蕉国产色戒| 久久婷婷五月综合国产尤物app| 午夜精品久久久久久影视777| 久久伊人中文无码| 久久久久久久91精品免费观看| 亚洲人成电影网站久久| 伊人久久大香线蕉AV色婷婷色|