• <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
            • 呵呵..把代碼發(fā)在這里很不錯..以后我也試試...百度的編輯器太爛了....
            • --csuft1

            閱讀排行榜

            評論排行榜

            搜索,把所有能走的點映射一下(這些點不多,最多100多個),狀態(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)  編輯 收藏 引用
            国内精品久久久久影院一蜜桃| AV无码久久久久不卡蜜桃| 日韩亚洲欧美久久久www综合网 | av色综合久久天堂av色综合在| 久久精品青青草原伊人| 久久久久久久久久久久中文字幕 | 久久人人爽爽爽人久久久| 久久久无码一区二区三区| 久久久久综合网久久| 午夜视频久久久久一区| 亚洲国产精品久久久天堂| 日韩亚洲欧美久久久www综合网 | 亚洲成人精品久久| 无码八A片人妻少妇久久| 久久99精品久久久久久动态图 | 亚洲国产天堂久久综合| 久久亚洲中文字幕精品有坂深雪 | 久久香蕉一级毛片| 伊人精品久久久久7777| 久久精品国产福利国产秒| 人妻无码αv中文字幕久久琪琪布| 粉嫩小泬无遮挡久久久久久| 久久夜色撩人精品国产| 91久久精品91久久性色| 久久亚洲中文字幕精品一区| 天天爽天天爽天天片a久久网| 欧美日韩久久中文字幕| 91亚洲国产成人久久精品网址 | 精品国产乱码久久久久软件| 久久最近最新中文字幕大全 | 国产精品久久久久久久久软件| 97久久香蕉国产线看观看| 欧美精品乱码99久久蜜桃| 国产高潮国产高潮久久久91| 一本久久a久久精品亚洲| 久久夜色精品国产www| 国产成人精品综合久久久| 久久精品国产亚洲AV大全| 久久亚洲国产精品成人AV秋霞| 狠狠色综合网站久久久久久久 | 漂亮人妻被黑人久久精品|