设为首页 加入收藏

TOP

HDU1429 胜利大逃亡(续) BFS +简单状压
2015-07-20 17:37:51 来源: 作者: 【 】 浏览:2
Tags:HDU1429 胜利 逃亡 BFS 简单

把手中持有的钥匙状态状压一下即可,然后vis访问标记的时候,开个三维,多一维即为当前持有钥匙状态,这样就能祛除重复标记困难走点的问题,跟网络赛那题很像,网络赛的更难点,这个简单点


int n,m,t;

int sx,sy,ex,ey;

char mp[20 + 55][20 + 55];

bool vis[20 + 5][20 + 5][(1<<10) + 5];

int dir[4][2] = {{1,0},{0,1},{-1,0},{0,-1}};

struct Node {
	int now;//现在钥匙状态
	int x,y;
	int step;
	friend bool operator<(Node aa,Node bb) {
		return aa.step > bb.step;
	}
};

void init() {
	memset(vis,false,sizeof(vis));
}

bool input() {
    while(cin>>n>>m>>t) {
		for(int i=0;i
  
    q;
	Node ss,ee;
	ss.x = x,ss.y = y,ss.step = 0,ss.now = 0;
	q.push(ss);
	vis[ss.x][ss.y][0] = true;
	while(!q.empty()) {
		ss = q.front();
		q.pop();
		if(ss.step >= t)continue;
		if(ss.x == ex && ss.y == ey) {
			ans = min(ans,ss.step);
			break;
		}
		for(int i=0;i<4;i++) {
			int dx = ss.x + dir[i][0];
			int dy = ss.y + dir[i][1];
			if(dx < 0 || dx >= n || dy < 0 || dy >= m)continue;
			if(mp[dx][dy] == '*')continue;
			if(vis[dx][dy][ss.now])continue;
			ee.now = ss.now;
			if(mp[dx][dy] >= 'A' && mp[dx][dy] <= 'J') {/*遇到门*/
				int tmp = mp[dx][dy] - 'A';
				if((ss.now&(1<
   
    = 'a' && mp[dx][dy] <= 'z') {/*遇到钥匙*/ int tmp = mp[dx][dy] - 'a'; ee.now |= (1<
    
     = t)puts("-1"); else cout<
     
      

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇HDU 1532 Drainage Ditches 最大.. 下一篇Codeforces Round #268 (Div. 1)B..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·数据库:推荐几款 Re (2025-12-25 12:17:11)
·如何最简单、通俗地 (2025-12-25 12:17:09)
·什么是Redis?为什么 (2025-12-25 12:17:06)
·对于一个想入坑Linux (2025-12-25 11:49:07)
·Linux 怎么读? (2025-12-25 11:49:04)