zoukankan      html  css  js  c++  java
  • HDU 1010 Tempter of the Bone

    题目链接:HDU 1010 Tempter of the Bone

    题目大意:
    一个大小为(N imes M)的迷宫中有一扇门,一开始门是关着的,它会在第(t)秒的时间打开。因此,小明和朋友必须在第(t)秒到大门口。每一秒,他都可以向上下左右四个方向移动一个点。一旦他移动了,他刚才所在的点就消失(这意味着他不能回到他已经走过的点),他不能在一个点上停留超过一秒,并且不能走障碍点,问小明和朋友能否安全逃出。

    题解:
    看题目就想到搜索,如果不做剪枝会超时,对于还没到开门时间,但已经经过门的情况,没必要再走下去,所以排除这些情况。

    #include <iostream>
    #include <cstring>
    using namespace std;
    #define io_speed_up ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
    #define ms(a, b) memset(a, b, sizeof(a))
    
    char mat[10][10];
    int n, m, t;
    int sx, sy, tx, ty;
    int dx[4] = {1, -1, 0, 0};
    int dy[4] = {0, 0, 1, -1};
    bool flag, use[10][10];
    
    void dfs(int step, int x, int y) {
    	if (step == t) {
    		if (x == tx && y == ty) {
    			flag = true;
    			return;
    		} else {
    			return;
    		}
    	}
    	if (use[tx][ty]) { // 没必要再走下去
    		return;
    	}
    	for (int i = 0; i < 4; ++i) {
    		if (flag) {
    			return;
    		}
    		int nx = x + dx[i];
    		int ny = y + dy[i];
    		if (!use[nx][ny] && nx >= 1 && ny >= 1 && nx <= n && ny <= m && mat[nx][ny] != 'X') {
    			use[nx][ny] = true;
    			dfs(step + 1, nx, ny);
    			use[nx][ny] = false;
    		}
    	}
    }
    
    int main() {
    	io_speed_up;
    	while (cin >> n >> m >> t) {
    		if (!n && !m && !t) {
    			break;
    		}
    		ms(use, 0);
    		for (int i = 1; i <= n; ++i) {
    			for (int j = 1; j <= m; ++j) {
    				cin >> mat[i][j];
    				if (mat[i][j] == 'S') {
    					sx = i, sy = j;
    				}
    				if (mat[i][j] == 'D') {
    					tx = i, ty = j;
    				}
    			}
    		}
    		flag = false;
    		use[sx][sy] = true;
    		dfs(0, sx, sy);
    		if (flag) {
    			cout << "YES" << endl;
    		} else {
    			cout << "NO" << endl;
    		}
    	}
    	return 0;
    }
    
  • 相关阅读:
    深入AXI4总线- [一]握手机制
    《数字集成电路静态时序分析基础》笔记⑩
    搭建自己的gitlab
    idea连接github问题
    itguang
    [转]springboot+idea热部署(自动刷新)
    25匹马,5条赛道,一匹马一个赛道,求决胜1,2,3名至少多少场
    [转]PostgreSQL主从流复制部署
    [转]centos7 安装jdk11 并设置默认java版本
    [转]centos7 修改yum源为阿里源
  • 原文地址:https://www.cnblogs.com/IzumiSagiri/p/13836649.html
Copyright © 2011-2022 走看看