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

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 閱讀(814) 評論(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>
            欧美日韩久久不卡| 欧美午夜欧美| 91久久国产综合久久蜜月精品| 久久福利影视| 久久精品国产一区二区三区| 韩国精品主播一区二区在线观看| 久久精品免视看| 美国成人毛片| 亚洲一区二区av电影| 亚洲一区二区三区在线看| 国产日韩一区二区三区在线| 久久一二三区| 欧美精品七区| 欧美一级网站| 久久最新视频| 国产精品99久久久久久久女警 | 亚洲精品国精品久久99热一| 亚洲精品乱码久久久久久日本蜜臀| 欧美国产精品v| 亚洲欧美日韩精品在线| 久久精品99无色码中文字幕| 亚洲大胆美女视频| 日韩视频在线一区二区三区| 国产日韩亚洲欧美| 欧美 日韩 国产在线| 欧美视频在线观看一区二区| 久久久亚洲一区| 欧美日韩ab片| 久久中文精品| 欧美涩涩网站| 久久综合九色综合欧美狠狠| 欧美日本亚洲| 蜜桃精品一区二区三区| 国产精品爱久久久久久久| 麻豆精品视频在线观看| 国产精品露脸自拍| 亚洲国产老妈| 韩日精品在线| 亚洲在线视频一区| 一本色道久久综合亚洲精品婷婷| 午夜精品久久| 亚洲桃色在线一区| 免费h精品视频在线播放| 久久精品国产清高在天天线| 欧美色图首页| 亚洲人成毛片在线播放| 激情成人av| 欧美一区二区三区视频在线| 中日韩视频在线观看| 久久永久免费| 亚洲欧美成人网| 亚洲在线视频一区| 蜜桃久久av一区| 欧美一区二区三区在线视频| 欧美日韩精品一区二区| 免费成人在线观看视频| 国产原创一区二区| 亚洲男人天堂2024| 亚洲欧美另类综合偷拍| 欧美日韩直播| 一区二区三区成人| 亚洲视频精品在线| 欧美日韩免费一区二区三区| 亚洲国产精品999| 一区二区视频免费在线观看 | 9久草视频在线视频精品| 91久久久久久久久| 久久综合电影一区| 亚洲第一区中文99精品| 亚洲激情一区二区| 欧美激情综合| 一本一本久久a久久精品牛牛影视| 亚洲欧洲日夜超级视频| 欧美大色视频| 亚洲美女av在线播放| 亚洲视频一区在线| 国产精品日本一区二区| 亚洲欧美电影院| 久久九九电影| 亚洲国产精品va在线观看黑人| 久久最新视频| 99视频在线观看一区三区| 亚洲一级在线| 国产主播一区二区| 老司机免费视频一区二区| 亚洲第一页中文字幕| 一区二区国产日产| 国产精品美女久久久久aⅴ国产馆| 亚洲一区二区在线看| 久久综合99re88久久爱| 亚洲欧洲精品一区二区三区不卡 | 最新成人av在线| 欧美日韩在线不卡一区| 亚洲新中文字幕| 葵司免费一区二区三区四区五区| 亚洲成人直播| 国产精品扒开腿爽爽爽视频| 欧美一级视频免费在线观看| 欧美激情a∨在线视频播放| 中文国产一区| 国产一区二区丝袜高跟鞋图片 | 亚洲麻豆av| 欧美一区二区在线视频| 亚洲高清自拍| 国产精品久线观看视频| 玖玖玖国产精品| 亚洲女人天堂av| 欧美激情1区2区| 久久国产精品久久久久久| 亚洲欧洲日韩综合二区| 国产欧美在线视频| 欧美片在线观看| 久久精品国产一区二区三区| 日韩午夜在线观看视频| 快播亚洲色图| 欧美一区亚洲| 一本大道av伊人久久综合| 黑人极品videos精品欧美裸| 欧美日韩国产欧| 久久综合网hezyo| 欧美在线|欧美| 一本色道久久综合亚洲精品婷婷| 美女诱惑一区| 久久久亚洲影院你懂的| 欧美亚洲综合久久| 在线视频亚洲| 亚洲精品美女| 亚洲动漫精品| 韩国精品在线观看| 国产日韩一区二区三区在线| 国产精品高清网站| 欧美色道久久88综合亚洲精品| 欧美成人一区二区三区| 久久精品免视看| 欧美在线播放| 香蕉久久夜色精品国产使用方法 | 久久伊人一区二区| 久久久国产精品亚洲一区| 香蕉成人伊视频在线观看| 亚洲图片在线| 亚洲一区二区三区视频播放| 亚洲美女电影在线| 一本大道久久精品懂色aⅴ| 亚洲日韩中文字幕在线播放| 亚洲高清一二三区| 亚洲激情网站免费观看| 亚洲国产精品一区| 亚洲国产高清在线| 亚洲黄色在线观看| 亚洲精品乱码久久久久久久久| 激情欧美日韩| 91久久精品网| 一区二区三区日韩精品视频| 一区二区三区.www| 亚洲一区尤物| 欧美一二三区在线观看| 久久久久免费观看| 乱码第一页成人| 亚洲高清不卡| 一区二区三区欧美成人| 亚洲欧美电影院| 久久久成人精品| 美女主播一区| 欧美天天在线| 国产一区二区中文| 亚洲第一在线| 一区二区三区产品免费精品久久75| 亚洲午夜一区二区三区| 欧美一进一出视频| 美女在线一区二区| 999亚洲国产精| 欧美一区二区三区免费视频| 免费欧美在线| 国产精品美女一区二区在线观看 | 欧美国产日韩a欧美在线观看| 欧美日韩久久不卡| 国产一区二区你懂的| 亚洲国产一区在线| 亚洲午夜精品一区二区| 久久久伊人欧美| 亚洲美女91| 久久人91精品久久久久久不卡| 欧美激情中文字幕一区二区| 国产欧美不卡| 日韩午夜在线电影| 久久成人在线| 日韩一区二区精品| 久久全球大尺度高清视频| 欧美午夜在线一二页| ●精品国产综合乱码久久久久| 亚洲深夜激情| 亚洲二区在线视频| 欧美专区福利在线| 欧美三级日本三级少妇99| 在线观看中文字幕不卡| 校园春色国产精品| 日韩视频免费在线观看| 麻豆精品精品国产自在97香蕉| 国产精品久久中文| 一区二区三区三区在线|