• <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 閱讀(776) 評論(1)  編輯 收藏 引用 所屬分類: 算法題解
            精品久久久久久国产| 亚洲AV伊人久久青青草原| 久久精品中文字幕久久| 国产99久久久国产精品~~牛| 久久久久国产一区二区三区| 99久久精品免费看国产一区二区三区 | 国产综合成人久久大片91| 久久天天躁狠狠躁夜夜躁2014| 精品久久8x国产免费观看| 亚洲欧美一区二区三区久久| 精品999久久久久久中文字幕| 日产精品久久久久久久| 国产精品日韩深夜福利久久| 久久久久人妻一区精品色| 久久精品国产男包| 久久久久18| 99久久伊人精品综合观看| 久久久久成人精品无码中文字幕| 日韩美女18网站久久精品| 国产精品久久久久天天影视| 亚洲国产精品无码久久一线| 亚洲国产天堂久久综合| 香蕉久久夜色精品国产小说| AV无码久久久久不卡蜜桃| 色88久久久久高潮综合影院| 久久人人爽人人爽人人片av麻烦| 久久久久久毛片免费看| 久久av免费天堂小草播放| www亚洲欲色成人久久精品| 久久综合九色综合97_久久久 | 久久99精品免费一区二区| 久久国产精品无码HDAV| 久久水蜜桃亚洲av无码精品麻豆| 精品国产乱码久久久久久人妻| 中文字幕久久精品| 精品久久久久成人码免费动漫| 日韩中文久久| 久久99国产精品久久99小说| 国产精品久久久久久久app| 中文字幕热久久久久久久| 久久亚洲精品中文字幕|