• <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出發,走到G可以充電,走到Y關掉開關,D不能走進,要求把所有開關關掉,且電量最少,并求出該最小電量。
            題解:不錯的題目,由于發現數據較小1<=n,m<=15,所以可以采用狀態壓縮DP解決。
            算法分3步:
            1.預處理,計算F、G、Y兩兩的距離(BFS)
            2.二分法求解最少電量
            3.狀態壓縮DP檢測當前電量為s時,能否走完,dp[s][x]表示狀態為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 閱讀(789) 評論(1)  編輯 收藏 引用 所屬分類: 算法題解
            色偷偷88888欧美精品久久久| 精品久久人人妻人人做精品| 久久精品卫校国产小美女| AV无码久久久久不卡蜜桃| 国产精品一区二区久久| 久久国产视频99电影| 囯产极品美女高潮无套久久久 | 久久国产亚洲精品无码| 国产成人精品久久一区二区三区av| 一个色综合久久| 国产亚洲婷婷香蕉久久精品| 久久婷婷色香五月综合激情 | 国产亚洲色婷婷久久99精品91| 无码8090精品久久一区| 久久99免费视频| 久久久久成人精品无码中文字幕| 欧美激情精品久久久久久| 久久免费小视频| 国内精品久久久久影院免费| 区久久AAA片69亚洲| 精品无码久久久久久久久久| 婷婷久久综合九色综合98| 狠狠色噜噜色狠狠狠综合久久 | 国内精品久久久久伊人av| 久久久久波多野结衣高潮| 久久久久久一区国产精品| 国产香蕉97碰碰久久人人| 91精品久久久久久无码| 久久天堂电影网| 97精品国产97久久久久久免费| 久久w5ww成w人免费| 精品国产乱码久久久久久1区2区| 少妇精品久久久一区二区三区| 97久久婷婷五月综合色d啪蜜芽| 久久人人添人人爽添人人片牛牛| 亚洲国产成人精品女人久久久| 人人狠狠综合88综合久久| 亚洲欧美一区二区三区久久| 国产精品久久久久久久人人看 | 久久综合色之久久综合| 亚洲欧洲精品成人久久曰影片|