• <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>
            posts - 33,  comments - 33,  trackbacks - 0
            題目鏈接:http://acm.hdu.edu.cn/showproblem.php?pid=3681
            題目大意:機器人從F出發(fā),走到G可以充電,走到Y(jié)關(guān)掉開關(guān),D不能走進,要求把所有開關(guān)關(guān)掉,且電量最少,并求出該最小電量。
            題解:不錯的題目,由于發(fā)現(xiàn)數(shù)據(jù)較小1<=n,m<=15,所以可以采用狀態(tài)壓縮DP解決。
            算法分3步:
            1.預(yù)處理,計算F、G、Y兩兩的距離(BFS)
            2.二分法求解最少電量
            3.狀態(tài)壓縮DP檢測當前電量為s時,能否走完,dp[s][x]表示狀態(tài)為s,最后到達x點,所剩余的最大電池量

            代碼:

            #include <stdio.h>
            #include 
            <queue>
            #include 
            <vector>
            #include 
            <string>
            #include 
            <iostream>
            using namespace std;

            const int N = 17;
            int dsx[4= {1,0,-1,0};
            int dsy[4= {0,1,0,-1};

            int dis[N][N][N][N];
            int dp[1 << 16][16];
            string map[N];
            int n,m;
            struct Point
            {
                
            int x;
                
            int y;
                Point(
            int _x = 0,int _y = 0):x(_x),y(_y){}
            }
            ;

            vector
            <Point> vecPoint;
            int startId;
            int yCnt = 0;
            int successState;

            void BFS(Point start)
            {
                queue
            <Point> que;
                dis[start.x][start.y][start.x][start.y] 
            = 0;
                que.push(start);
                Point cur;
                Point next;
                
            while(!que.empty())
                
            {
                    cur 
            = que.front();
                    que.pop();
                    
            for(int i = 0; i < 4++i)
                    
            {
                        next.x 
            = cur.x + dsx[i];
                        next.y 
            = cur.y + dsy[i];
                        
            if((next.x >= 0 && next.x < n) && (next.y >= 0 && next.y < m))
                        
            {
                            
            if((map[cur.x][cur.y] != 'D'&& (dis[start.x][start.y][next.x][next.y] == -1))
                            
            {
                                dis[start.x][start.y][next.x][next.y] 
            = dis[start.x][start.y][cur.x][cur.y] + 1;
                                que.push(next);
                            }

                        }

                    }

                }

            }


            int BIT(int state,int j)
            {
                
            return ( (state & (1 << j)) >> (j) );
            }


            int SET(int state,int j)
            {
                
            return (state |= (1 << j));
            }


            bool Contain(int state,int sub)
            {
                
            return ((state&sub) == sub);
            }


            bool Check(int step)
            {
                memset(dp,
            -1,sizeof(dp));
                dp[
            1<<startId][startId] = step;
                
            int opt = -1;
                
            int num = vecPoint.size();
                
            for(int i = 0; i < (1 << num); ++i)
                
            {
                    
            for(int j = 0; j < num; ++j)
                    
            {
                        
            if(dp[i][j] != -1 && BIT(i,j) != 0)
                        
            {
                            
            if(Contain(i,successState))
                                opt 
            = max(opt,dp[i][j]);
                            
            for(int k = 0; k < num; ++k)
                            
            {
                                
            if(BIT(i,k) == 0)
                                
            {
                                    
            int sa = SET(i,k);
                                    
            if(dis[vecPoint[j].x][vecPoint[j].y][vecPoint[k].x][vecPoint[k].y] != -1)
                                    
            {
                                        
            int tmp = dp[i][j] - dis[vecPoint[j].x][vecPoint[j].y][vecPoint[k].x][vecPoint[k].y];
                                        
            if(tmp >= 0)
                                        
            {
                                            
            if(dp[sa][k] == -1)
                                                dp[sa][k] 
            = tmp;
                                            
            else if(dp[sa][k] < tmp)
                                                dp[sa][k] 
            = tmp;
                                            
            if(map[vecPoint[k].x][vecPoint[k].y] == 'G')
                                                dp[sa][k] 
            = step;
                                        }

                                    }

                                }

                            }

                        }

                    }

                }

                
            return (opt >= 0);
            }


            int BinarySlove(int low,int high)
            {
                
            int mid = 0;
                
            int ans = 1 << 30;
                
            while(low <= high)
                
            {
                    mid 
            = (low + high)/2;
                    
            if(Check(mid))
                    
            {
                        ans 
            = min(ans,mid);
                        high 
            = mid - 1;
                    }

                    
            else
                    
            {
                        low 
            = mid + 1;
                    }

                }

                
            if(ans != 1 << 30)
                    
            return ans;
                
            else
                    
            return -1;
            }


            void Test()
            {
                vecPoint.clear();
                yCnt 
            = 0;
                successState 
            = 0;
                
            for(int i = 0; i < n; ++i)
                
            {
                    cin 
            >> map[i];
                    
            for(int j = 0; j < map[i].length(); ++j)
                    
            {
                        
            switch(map[i][j])
                        
            {
                        
            case 'F':
                            vecPoint.push_back(Point(i,j));
                            startId 
            = vecPoint.size() - 1;
                            successState 
            |= (1 << startId);
                            
            break;
                        
            case 'G':
                            vecPoint.push_back(Point(i,j));
                            
            break;
                        
            case 'Y':
                            
            ++yCnt;
                            vecPoint.push_back(Point(i,j));
                            
            int id = vecPoint.size() - 1;
                            successState 
            |= (1 << id);
                            
            break;
                        }

                    }

                }

                
            //pre
                memset(dis,-1,sizeof(dis));
                
            for(int i = 0; i < vecPoint.size(); ++i)
                    BFS(vecPoint[i]);
                
            int limit = vecPoint.size() * vecPoint.size();
                printf(
            "%d\n",BinarySlove(0,limit));
            }


            int main()
            {
                
            while(scanf("%d %d",&n,&m) != EOF)
                
            {
                    
            if(n == 0 || m == 0)
                        
            break;
                    Test();
                }

                
            return 0;
            }
            posted on 2010-11-10 16:54 bennycen 閱讀(776) 評論(1)  編輯 收藏 引用 所屬分類: 算法題解
            久久精品国产AV一区二区三区| 久久成人国产精品| 香蕉久久影院| 亚洲AV乱码久久精品蜜桃| 精品精品国产自在久久高清| 久久av免费天堂小草播放| 中文国产成人精品久久不卡| 日韩欧美亚洲综合久久影院d3| 亚洲精品tv久久久久久久久久| 久久久久99精品成人片试看| 久久露脸国产精品| 999久久久无码国产精品| 亚洲&#228;v永久无码精品天堂久久 | 1000部精品久久久久久久久| 日韩久久久久中文字幕人妻| 国内精品伊人久久久久| 国产美女亚洲精品久久久综合| 久久久精品日本一区二区三区| 国产精品久久久久久搜索| 欧美精品国产综合久久| 精品久久久久中文字幕一区| 免费国产99久久久香蕉| 久久久久亚洲精品无码蜜桃| 久久天天躁狠狠躁夜夜躁2014| 欧美久久久久久午夜精品| 久久福利青草精品资源站免费| 久久九九精品99国产精品| 久久夜色精品国产欧美乱| 久久精品aⅴ无码中文字字幕不卡 久久精品成人欧美大片 | 青草久久久国产线免观| 日本三级久久网| 一本大道久久a久久精品综合| 久久免费的精品国产V∧| 7777久久久国产精品消防器材 | 97久久久精品综合88久久| 狠狠色狠狠色综合久久| 久久人人爽人人人人片av| 欧美亚洲国产精品久久| 欧美成人免费观看久久| 久久久噜噜噜久久中文字幕色伊伊| 99久久国产亚洲综合精品|