• <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關掉開關,D不能走進,要求把所有開關關掉,且電量最少,并求出該最小電量。
            題解:不錯的題目,由于發(fā)現(xiàn)數(shù)據(jù)較小1<=n,m<=15,所以可以采用狀態(tài)壓縮DP解決。
            算法分3步:
            1.預處理,計算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 閱讀(789) 評論(1)  編輯 收藏 引用 所屬分類: 算法題解
            嫩草伊人久久精品少妇AV| 一本久久知道综合久久| 中文字幕久久精品无码| 无码8090精品久久一区| 久久久无码精品亚洲日韩蜜臀浪潮| 亚洲精品视频久久久| 精品精品国产自在久久高清| 亚洲色大成网站www久久九| 久久只有这精品99| 久久天天日天天操综合伊人av| 久久免费国产精品一区二区| 精品蜜臀久久久久99网站| 国产综合久久久久| 国产69精品久久久久99尤物| 国产精品99久久精品| 久久伊人精品青青草原高清| 伊人久久综在合线亚洲2019| 88久久精品无码一区二区毛片| 精品国产91久久久久久久a| 久久99亚洲综合精品首页| 亚洲精品成人久久久| 成人久久免费网站| 狠狠狠色丁香婷婷综合久久五月| 热99re久久国超精品首页| 精品国产91久久久久久久a| 伊人久久大香线蕉成人| 久久久久亚洲av无码专区喷水| 91久久婷婷国产综合精品青草| 免费国产99久久久香蕉| 性做久久久久久久久久久| 精品国际久久久久999波多野| 一本久久a久久精品综合夜夜| 久久综合久久伊人| 97精品伊人久久大香线蕉app| 久久精品国产色蜜蜜麻豆| 亚洲精品美女久久久久99| 久久最近最新中文字幕大全 | 国产成人无码精品久久久免费| 久久久精品国产Sm最大网站| 亚洲国产另类久久久精品黑人 | 久久久久久久久久久精品尤物|