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

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

代碼:

#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) 評(píng)論(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>
            久久av最新网址| 欧美日韩裸体免费视频| 亚洲国产另类 国产精品国产免费| 亚洲色图制服丝袜| 亚洲一级黄色av| 亚洲综合视频网| 欧美亚洲视频在线观看| 久久国产精品久久w女人spa| 久久成人18免费网站| 欧美日韩国内| 欧美偷拍一区二区| 国产亚洲欧美aaaa| 亚洲国产天堂久久综合网| 夜夜嗨av一区二区三区网页 | 亚洲国产99精品国自产| 亚洲国产综合在线| 亚洲永久字幕| 狼狼综合久久久久综合网| 亚洲欧洲日本国产| 亚洲男人第一网站| 牛夜精品久久久久久久99黑人| 老牛影视一区二区三区| 欧美日一区二区三区在线观看国产免 | 麻豆国产精品一区二区三区 | 在线不卡中文字幕| 亚洲天堂av在线免费| 久久久久欧美精品| 亚洲精品免费看| 欧美一区二区视频在线| 欧美人在线观看| 激情成人在线视频| 亚洲欧美中文另类| 亚洲国产91精品在线观看| 亚洲欧美视频一区| 欧美激情自拍| 在线观看日韩专区| 小黄鸭精品aⅴ导航网站入口| 久久综合色天天久久综合图片| 亚洲精品国久久99热| 久久激情网站| 国产精品欧美精品| 一区电影在线观看| 欧美国产精品劲爆| 久久精品国产精品亚洲精品| 欧美日韩一区二区三区免费看| 经典三级久久| 久久黄色级2电影| 中文国产成人精品久久一| 欧美91精品| 亚洲第一毛片| 老司机67194精品线观看| 亚洲午夜精品网| 欧美日韩亚洲一区二区三区| 亚洲三级影院| 欧美成人影音| 久久视频在线视频| 激情成人中文字幕| 久久久久国产免费免费| 亚洲一二三区精品| 国产精品白丝黑袜喷水久久久| 亚洲精品三级| 欧美成人一区二区三区在线观看| 亚洲综合精品一区二区| 亚洲午夜精品一区二区| 欧美日韩一区二区在线观看| aⅴ色国产欧美| 亚洲国产视频一区| 欧美黄色大片网站| 一区二区日韩伦理片| 99精品视频网| 国产精品嫩草影院av蜜臀| 欧美在线视频一区| 久久五月婷婷丁香社区| 欧美一区二区在线免费观看| 国产在线播放一区二区三区| 久久亚洲综合色一区二区三区| 久久精品一区二区国产| 亚洲国产国产亚洲一二三| 亚洲国产成人av| 欧美视频一区二区三区| 亚洲欧美日韩精品久久久| 亚洲影院色在线观看免费| 国内精品久久久久影院优 | 99这里只有精品| 欧美日本乱大交xxxxx| 亚洲欧美日韩一区在线观看| 欧美亚洲一区二区在线观看| 午夜伦欧美伦电影理论片| 在线视频观看日韩| 亚洲欧洲精品一区二区三区不卡| 欧美视频一区二| 久久精品人人做人人综合| 免费不卡在线观看| 亚洲综合99| 开元免费观看欧美电视剧网站| 亚洲人成网站影音先锋播放| av成人老司机| 黄色一区二区三区| 99国产精品久久久久老师| 国语对白精品一区二区| 亚洲国产视频一区| 国产农村妇女精品| 亚洲激情视频在线| 欧美伊久线香蕉线新在线| 亚洲激情视频网| 亚洲欧美精品suv| 亚洲精品免费电影| 欧美在线免费观看视频| 一区二区三区四区国产| 先锋影音网一区二区| 亚洲精品欧美在线| 欧美在线免费视频| 亚洲自拍偷拍视频| 欧美成人自拍| 老鸭窝91久久精品色噜噜导演| 欧美日韩的一区二区| 免费看的黄色欧美网站| 国产精品白丝av嫩草影院| 欧美国产精品专区| 国产一区激情| 午夜日韩激情| 亚洲欧美国产日韩中文字幕| 欧美成人午夜视频| 欧美不卡在线视频| 国产区精品视频| 亚洲四色影视在线观看| 欧美日韩在线亚洲一区蜜芽| 免费成人黄色av| 国外成人在线| 欧美伊人久久| 久久精品理论片| 国产欧美精品一区二区三区介绍| 亚洲精品资源| 亚洲精品日韩一| 欧美精品国产精品| 亚洲第一精品夜夜躁人人躁| 激情久久久久久久| 欧美在线观看视频一区二区| 亚洲电影免费观看高清完整版在线 | 国产日韩欧美在线观看| 亚洲午夜免费视频| 亚洲欧美日韩精品久久久久| 欧美天堂亚洲电影院在线播放| 亚洲精品日韩综合观看成人91| 亚洲精品激情| 欧美另类女人| 亚洲色无码播放| 欧美一区二区高清| 国产一区二区电影在线观看 | 欧美精品一区在线| 亚洲人妖在线| 亚洲影视综合| 国产精品婷婷午夜在线观看| 午夜国产一区| 麻豆九一精品爱看视频在线观看免费| 在线观看欧美激情| 欧美激情精品| 亚洲女与黑人做爰| 美女主播一区| 亚洲国产日本| 国产精品超碰97尤物18| 欧美亚洲一区二区在线| 狂野欧美一区| 一区二区三区四区五区精品视频| 欧美日韩一区二区三区四区在线观看| 洋洋av久久久久久久一区| 欧美一级日韩一级| 亚洲国产精品va在看黑人| 欧美日韩国产综合视频在线观看| 亚洲视频中文字幕| 嫩模写真一区二区三区三州| 一区二区三区四区国产| 国产婷婷色一区二区三区四区| 久久五月激情| 亚洲一区999| 欧美大片免费| 香蕉精品999视频一区二区| 伊人精品久久久久7777| 欧美系列亚洲系列| 久久一二三区| 午夜老司机精品| 99精品视频免费观看| 欧美 日韩 国产一区二区在线视频 | 亚洲精品日韩在线| 美女任你摸久久| 亚洲一区二区免费看| 在线不卡中文字幕| 国产毛片久久| 欧美视频国产精品| 久久久99精品免费观看不卡| 99视频有精品| 亚洲激情电影在线| 国内精品久久久久影院 日本资源 国内精品久久久久伊人av | 激情文学一区| 国产精品久久久一区二区三区| 免费不卡视频| 久久久久国内| 欧美一区二区视频免费观看| 一区二区三区视频在线看 | 久久久久国产精品www|