青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

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 閱讀(804) 評論(1)  編輯 收藏 引用 所屬分類: 算法題解
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧美日韩成人| 亚洲免费精品| 亚洲精品1234| 激情综合中文娱乐网| 国内精品福利| 最新高清无码专区| 亚洲狼人综合| 亚洲视频久久| 久久精品电影| 牛牛影视久久网| 亚洲精品资源| 亚洲一区二区三区精品在线| 亚洲欧美日韩精品在线| 久久九九电影| 欧美日韩爆操| 国产欧美精品xxxx另类| 精品1区2区3区4区| 在线亚洲观看| 另类天堂av| 亚洲精品午夜| 久久精品免费播放| 欧美日韩在线免费观看| 国产亚洲精品aa| 99成人在线| 久久久久久久一区二区三区| 最新日韩在线| 欧美一区二区女人| 欧美日本高清视频| 黄色亚洲在线| 午夜亚洲影视| 91久久国产综合久久91精品网站| 在线视频精品一区| 美日韩精品免费| 国产亚洲成精品久久| 日韩一级不卡| 欧美激情成人在线视频| 亚洲欧美中文另类| 欧美色精品天天在线观看视频| 亚洲福利国产| 欧美伊人影院| 亚洲一区二区黄色| 欧美日韩系列| 99国产精品99久久久久久粉嫩| 久久久久久久波多野高潮日日| 亚洲精品久久久久| 嫩草成人www欧美| 一区二区在线不卡| 久久国产视频网站| 亚洲自啪免费| 国产精品毛片大码女人| 99在线精品视频| 亚洲国产精品一区二区第一页| 性欧美精品高清| 国产婷婷色一区二区三区四区| 亚洲永久免费观看| 亚洲人久久久| 亚洲电影在线观看| 久久亚洲精品网站| 黄色免费成人| 六月天综合网| 久久综合狠狠| 91久久综合| 欧美国产先锋| 欧美日本亚洲韩国国产| 日韩亚洲欧美在线观看| 亚洲人成7777| 欧美偷拍一区二区| 午夜精品久久久久久久久| 一区二区三区四区五区视频| 欧美三区在线| 亚洲欧美电影在线观看| 夜夜嗨av一区二区三区| 欧美色图首页| 久久久久久久久久久久久女国产乱 | 欧美日韩亚洲一区| 一区二区激情视频| 在线性视频日韩欧美| 国产精品久久久久免费a∨大胸| 午夜在线a亚洲v天堂网2018| 欧美一区二区三区免费视| 精品福利免费观看| 亚洲高清视频的网址| 欧美日韩国产区一| 欧美一区二区三区播放老司机| 性欧美大战久久久久久久免费观看| 国内精品99| 亚洲精品欧美精品| 国产一区久久久| 亚洲成人在线视频播放| 欧美日韩一区不卡| 久久久久久自在自线| 欧美va日韩va| 亚洲女同性videos| 久久久国产一区二区三区| 亚洲美女av网站| 欧美一级久久久| 日韩网站在线看片你懂的| 亚洲一区二区视频在线| 在线免费精品视频| 亚洲在线视频观看| 亚洲精品美女在线观看| 亚洲专区在线| 日韩一区二区福利| 久久精品国产成人| 亚洲女同同性videoxma| 久久亚洲国产成人| 午夜久久美女| 欧美激情一区二区三区高清视频| 欧美伊人久久久久久久久影院| 欧美福利视频在线观看| 久久一区二区三区av| 欧美三区在线观看| 亚洲国产国产亚洲一二三| 国产在线观看一区| 亚洲一区中文| 欧美不卡在线视频| 久久午夜视频| 国产精品人人做人人爽人人添| 亚洲福利视频网站| 狠狠色香婷婷久久亚洲精品| 亚洲一区二区三区在线播放| 亚洲免费观看高清完整版在线观看熊| 欧美在线一级视频| 亚洲欧美在线免费| 欧美日韩在线大尺度| 亚洲精品乱码久久久久久蜜桃91| 亚洲电影观看| 久久蜜桃资源一区二区老牛| 久久久免费观看视频| 国产视频久久久久久久| 亚洲一级在线观看| 先锋资源久久| 国产精品尤物| 香蕉成人久久| 久久久99精品免费观看不卡| 国产欧美va欧美va香蕉在| 亚洲一区二区在线| 久久国产精品99国产精| 国产欧美日韩另类视频免费观看| 亚洲综合清纯丝袜自拍| 新67194成人永久网站| 国产欧美日韩在线视频| 性欧美18~19sex高清播放| 欧美与黑人午夜性猛交久久久| 国产精品永久在线| 久久久精品国产99久久精品芒果| 久久在线播放| 最新精品在线| 欧美日韩精品一区二区在线播放| 日韩午夜在线| 香蕉久久精品日日躁夜夜躁| 国产精品资源| 久久久综合精品| 亚洲盗摄视频| 亚洲一区二区三区免费视频| 国产精品日韩欧美| 久久久国产一区二区| 亚洲激情在线激情| 午夜国产不卡在线观看视频| 国产最新精品精品你懂的| 蜜臀av性久久久久蜜臀aⅴ| 91久久久久久国产精品| 香港成人在线视频| 亚洲国产欧美日韩| 欧美日韩直播| 欧美一区二区精品久久911| 欧美成人午夜免费视在线看片| 日韩视频欧美视频| 国产午夜精品久久久| 欧美精品免费在线| 欧美亚洲自偷自偷| 亚洲精品自在久久| 久热精品在线| 亚洲免费一级电影| 亚洲国产一成人久久精品| 国产精品xnxxcom| 久久久综合香蕉尹人综合网| 一区二区不卡在线视频 午夜欧美不卡' | 亚洲国产女人aaa毛片在线| 亚洲一区日韩| 亚洲欧洲精品一区二区三区 | 亚洲国产精品久久91精品| 欧美日韩免费观看中文| 羞羞漫画18久久大片| 一区二区在线观看视频在线观看| 欧美日韩岛国| 久久国产精品99精品国产| 亚洲精品一二三区| 久久综合九色欧美综合狠狠| 国产精品99久久久久久久久| 国内精品久久久久伊人av| 欧美日韩一区二区高清| 久久亚洲一区二区三区四区| 亚洲一区二区毛片| 亚洲免费观看高清在线观看| 另类av导航| 久久九九国产| 欧美亚洲在线观看| 99精品国产在热久久| 在线观看日韩国产|