HDU 1010 Tempter of the Bone
来源:互联网 发布:php直销源码 编辑:程序博客网 时间:2024/06/04 18:58
问题描述
Tempter of the Bone
简述:有一只小狗在迷宫里触发了机关,s表示小狗所在位置,给定矩阵N*M,时间t。移动一个格子需要1s。
问:是否恰好t时间时,小狗走到D位置
思路:dfs练习,从小狗位置开始深搜。
我第一次submit的时候没有使用奇偶剪枝,所以TLE,不难想到,TLE的原因就是剪枝不到位,因此在网上搜索了其他人的代码,最终AC。
剪枝状况:
1.越出边界;
2.已访问过;
3.遇墙;
4.奇偶剪枝(重要);
有关奇偶剪枝请百度;
下面贴出CODE:
# include <cstdio># include <cstring># include <iostream># include <cmath>using namespace std;const int maxn = 10;char a[maxn][maxn];int vis[maxn][maxn];int n, m, t;int kase;int sx, sy,dx,dy;int dis(int x,int y) {return abs((double)x - dx) + abs((double)y - dy);}void dfs(int x, int y,int cnt) {if (kase == 1)return;if (x < 0 || x == n || y < 0 || y == m|| a[x][y] == 'X'||vis[x][y]==1)return;if (a[x][y] == 'D' && cnt == t ) {kase = 1;return;}if (cnt >= t)return;int di = t - cnt - dis(x,y);if (di < 0 || di % 2)//di%2为奇偶剪枝条件return;if (vis[x][y] == 0) {vis[x][y] = 1;dfs(x - 1, y, cnt + 1);dfs(x, y - 1, cnt + 1);dfs(x + 1, y, cnt + 1);dfs(x, y + 1, cnt + 1);vis[x][y] = 0;}}int main() {while (scanf("%d%d%d", &n, &m, &t) == 3) {if (n == 0 && m == 0 && t == 0)return 0;kase = 0;memset(a, 0, sizeof(a));memset(vis, 0, sizeof(vis));for (int i = 0; i < n; i++) {for (int j = 0; j < m; j++) {cin >> a[i][j];if (a[i][j] == 'S') {sx = i;sy = j;}if (a[i][j] == 'D') {dx = i;dy = j;}}}dfs(sx, sy, 0);if (kase == 0)puts("NO");elseputs("YES");}return 0;}
阅读全文
0 0
- HDU 1010 Tempter of the Bone
- 迷宫 hdu 1010 Tempter of the Bone
- HDU 1010-Tempter of the Bone
- hdu 1010 Tempter of the Bone
- HDU 1010 Tempter of the Bone
- HDU 1010 Tempter of the Bone
- hdu 1010 Tempter of the Bone(深搜)
- HDU 1010 Tempter of the Bone
- HDU 1010 Tempter of the Bone
- HDU 1010 Tempter of the Bone
- hdu 1010 Tempter of the Bone
- HDU-1010-Tempter of the Bone
- hdu 1010 Tempter of the Bone
- HDU 1010-Tempter of the Bone
- HDU 1010 Tempter of the Bone (DFS)
- hdu 1010 Tempter of the Bone
- HDU 1010 - Tempter of the Bone
- hdu 1010 Tempter of the Bone
- 安卓的时间转换--数据库Date类型
- Docker 架构
- keil5自动提示功能无法提示结构体成员变量
- 第八课 使用数据处理函数
- JavaScript eval处理JSON数据 为什么要加括号
- HDU 1010 Tempter of the Bone
- ASP.NET AspNetPager居中样式
- 发送请求的参数值中含有类型为textarea的input框的值且当输入有回车换行时,md5加密生成sign验证失败,
- linux 、unix下启动停止oracle服务和监听
- linux下tftp安装
- C++中字符串的分割
- Softmax 一文看懂Softmax函数
- javaEE项目中WEB-INF目录
- ssm项目下遇到的404问题