• <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 閱讀(93) 評論(0)  編輯 收藏 引用
            久久成人永久免费播放| 欧美黑人激情性久久| 国产999精品久久久久久| 国产精品免费久久久久久久久| 久久精品一区二区影院| 亚洲乱码精品久久久久..| yellow中文字幕久久网| 中文字幕无码久久人妻| 狠狠色丁香婷婷久久综合不卡| 日韩电影久久久被窝网| 国内精品久久久久影院一蜜桃| 久久综合一区二区无码| 97久久精品午夜一区二区| 四虎久久影院| 国产午夜福利精品久久| 久久午夜福利无码1000合集| 国产精品欧美久久久久无广告| 亚洲国产精品无码久久久蜜芽| 久久国产精品一区| 国产精品狼人久久久久影院| 无码精品久久久天天影视| 亚洲国产精品综合久久一线| 91超碰碰碰碰久久久久久综合| 久久精品国产久精国产思思| 要久久爱在线免费观看| 一级女性全黄久久生活片免费| 久久久九九有精品国产| a级成人毛片久久| 精品国产VA久久久久久久冰 | 99久久99久久久精品齐齐 | 国产激情久久久久久熟女老人| 久久天天躁狠狠躁夜夜av浪潮 | 欧美丰满熟妇BBB久久久| 久久只有这精品99| 一本久久综合亚洲鲁鲁五月天| 久久久久97国产精华液好用吗| 国产免费福利体检区久久| 久久嫩草影院免费看夜色| 久久精品国产亚洲Aⅴ香蕉| 久久婷婷人人澡人人| 久久精品极品盛宴观看|