hdu1010 dfs+路径剪枝
题意:用一个案例来解释
4 4 5
S.X.
..X.
..XD
.... 在这个案例中,是一个4*4的地图。 . 表示可走的地方, X 表示不可走的地方,S表示起始点,D表示目标点。没走到一个点之后。这个点就不可走啦。起始点的时间是0,那么问 在 时间刚好是 5 的时候能不能走到 D ,对于这个案例来说显然不能
题解:这里学习到了一个剪枝 : 路径剪枝,是看了这个博客的解释,结合题目讲了两个剪枝,讲得非常具体:
tid=6158">http://acm.hdu.edu.cn/forum/read.php?tid=6158
另一个地方须要注意的就要是,在用到 abs 函数的时候,默认 abs 參数是不包含 int 类型的,会报错,须要加入 stdlib.h 头文件
- #include <iostream>
- #include <cstdio>
- #include <cstdlib>
- #include <cstring>
- using namespace std;
- int N,M,T;
- char map[10][10];
- bool flag[10][10];
- struct Node{
- int x,y,step;
- }S,E;
- int vis[4][2] = {1,0,-1,0,0,1,0,-1};
- bool OK;//用来标记是否在搜索中找到,假设找到了就能够直接推断,在递归中退出
- bool dfs(Node n)
- {
- if(n.x == E.x && n.y == E.y && n.step == T){
- OK = true; return true;
- }
- //路径剪枝
- int temp =T-n.step-abs(n.x-E.x)-abs(n.y-E.y);
- if(temp < 0 || temp&1) return false;
- for(int i = 0; i < 4; i ++){
- Node pre;
- pre.x = n.x+vis[i][0]; pre.y = n.y+vis[i][1];
- if(pre.x>=0 && pre.x<N && pre.y>=0 && pre.y < M && map[pre.x][pre.y] != 'X'){
- pre.step = n.step+1;
- map[pre.x][pre.y] = 'X';
- dfs(pre);
- if(OK) return true;
- map[pre.x][pre.y] = '.';
- }
- }
- return false;
- }
- int main()
- {
- while(scanf("%d%d%d",&N,&M,&T))
- {
- if(!N && !M && !T) break;
- for(int i = 0; i < N; i ++) scanf("%s",map[i]);//cin >> map[i];
- for(int i = 0; i < N; i ++){
- for(int j = 0; j < M; j ++){
- if(map[i][j] == 'S') S.x = i,S.y = j;
- if(map[i][j] == 'D') E.x = i,E.y = j;
- }
- }
- memset(flag,false,sizeof(flag));
- map[S.x][S.y] = 'X';
- S.step = 0;
- OK = false;
- if(dfs(S)) cout << "YES" <<endl;
- else cout << "NO" <<endl;
- }
- return 0;
- }
hdu1010 dfs+路径剪枝的更多相关文章
- hdu1010 Tempter of the Bone —— dfs+奇偶性剪枝
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1010 Tempter of the Bone Time Limit: 2000/1000 MS (Ja ...
- hdoj--1010<dfs+奇偶剪枝>
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1010 题目描述:在n*m的矩阵中,有一起点和终点,中间有墙,给出起点终点和墙,并给出步数,在该步数情况 ...
- hdu-1010 dfs+剪枝
思路: 剪枝的思路参考博客:http://www.cnblogs.com/zibuyu/archive/2012/08/17/2644396.html 在其基础之上有所改进 题意可以给抽象成给出一个 ...
- HDU1010 Tempter of the Bone【小狗是否能逃生----DFS奇偶剪枝(t时刻恰好到达)】
Tempter of the Bone Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u ...
- HDU1010 DFS+剪枝
Tempter of the Bone Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Othe ...
- hdu1010 - dfs,奇偶剪枝
题目链接 给一个迷宫,问从起点到终点存不存在一条长度为T的路径. ------------------------------------------------------------------- ...
- hdu - 1010 Tempter of the Bone (dfs+奇偶性剪枝) && hdu-1015 Safecracker(简单搜索)
http://acm.hdu.edu.cn/showproblem.php?pid=1010 这题就是问能不能在t时刻走到门口,不能用bfs的原因大概是可能不一定是最短路路径吧. 但是这题要过除了细心 ...
- poj 3134 Power Calculus(迭代加深dfs+强剪枝)
Description Starting with x and repeatedly multiplying by x, we can compute x31 with thirty multipli ...
- Tempter of the Bone(dfs奇偶剪枝)
Tempter of the Bone Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Othe ...
随机推荐
- (二)openvpn客户端配置
1)下载和安装openvpn客户端 下载连接:https://build.openvpn.net/downloads/releases/ 注意:这里下载连接使用国内的网已被强,我通过FQ下载 链接:h ...
- POJ 2018 Best Cow Fences
斜率优化. 设$s[i]$表示前缀和,$avg(i,j)=(s[j]-s[i-1])/(j-(i-1))$.就是$(j,s[j])$与$(i-1,s[i-1])$两点之间的斜率. 如果,我们目前在计算 ...
- n2n搭建手记-1-V1
搭建环境 supernode :阿里云主机一台 aly1(Centos 6.5) edg2node:美团云机器两台 mty1,mty2(Centos 7.0) Step-1 各机器安装subviers ...
- NAT穿透工具pwnat
NAT穿透工具pwnat 由于网络环境的限制,大部分计算机都不在公网中,而是位于NAT或者防火墙之后.这时,不同NAT之后的计算机通信就受到限制.为了解决这个问题,Kali Linux提供了一个N ...
- 【动态规划】bzoj1638 [Usaco2007 Mar]Cow Traffic 奶牛交通
设f[u]为从度数0到u的路径条数,f2[u]为从u到n的路径条数. ans=max{f[x[i]]*f2[y[i]]}(1<=i<=m). #include<cstdio> ...
- 【费马小定理+快速幂+逆元】BZOJ3240-[NOI2013]矩阵游戏
[题目大意] 若用F[i][j]来表示矩阵中第i行第j列的元素,则F[i][j]满足下面的递推式:F[1][1]=1F[i,j]=a*F[i][j-1]+b (j!=1)①F[i,1]=c*F[i-1 ...
- 【AC自动机/fail树】BZOJ3172- [Tjoi2013]单词
[题目大意] http://www.lydsy.com:808/JudgeOnline/problem.php?id=3172 某人读论文,一篇论文是由许多单词组成.但他发现一个单词会在论文中出现很多 ...
- 如何在debug模式下,使用正式的签名文件
有两种方式(在集成第三方库的使用 使用的非常多) 签名配置信息 一是直接按F4,在项目结构面板中进行设置,只要操作两个两个选项卡就好了,signing(生成配置信息)和build types(打包类 ...
- SublimeText3插件Emmet自定义HTML
工作上总使用Sublime,Emmet默认生成html格式不太满足需要,生成后还需要额外添加一些元素,如下是自定义html格式的步骤,供大家参考: 1. 安装Sublime Text3.Emmet插件 ...
- 【java】子类可以通过调用父类的public方法调用父类的private方法,为什么?
代码1: 打印结果: 代码2: 运行结果: 问题: 代码1中super是父类自己调用自己的add()方法,并在add()方法中调用了私有的del()方法,那为什么打印出来的this是子类? 代码2中t ...