http://acm.hdu.edu.cn/showproblem.php?pid=1010

题意很好理解,不是最短路,而是dfs,虽然地图不算大,稍微注意一点的dfs也能险过,但是700+ms和78ms一对比还是让人难受

对dfs的剪枝处理,实际上就是一个逻辑推理

面对整个地图我可以做出以下判断如果 n * m - wall <= t那就一定say NO

n * m 是整个地图的大小,wall是地图中墙的个数相减之后就是最多可以走的步数,之所以取到等号是因为在第0秒的时候,已经走了一个地方了(起点)

这就是路径剪枝
接下来看一看奇偶剪枝:

奇偶剪枝:
把矩阵标记成如下形式
0,1,0,1,0
1,0,1,0,1
0,1,0,1,0
1,0,1,0,1

起点和终点奇偶不同——要走奇数步,奇偶相同——要走偶数步,与路径剪纸不同的是奇偶剪纸可以放到dfs里,对dfs的优化效果也很好

进而可以推出下面的关系(他们之间的关系有一个就是奇数-奇数=偶数,偶数-偶数=偶数,所以如果temp是奇数,那么就say no)

 令 temp = (t - step) - (abs(sx - ex) + abs(sy - ey));
    abs(sx - ex) + abs(sy - ey)到达终点最少还要的步数
    t - step 还剩下的步数
    1——》temp < 0 肯定到不了了return
    2——》temp > 0 
    (1)temp是奇数 --》绕道多走必然多走偶数步-出去一步,进来以不,
    //例如走a b你可以试一试无论怎么走再回到正轨上肯定多走偶数步所以retur
    (2)temp是偶数--》可以正常dfs

#include <iostream>
#include <cstdio>
#include <string>
#include <string.h>
using namespace std;
const int maxn = 10;
int mp[10][10];
int vis[10][10];
int foot[4][2] = {1,0,-1,0,0,1,0,-1};
int n,m,t,sx,sy,ex,ey,wall;
int retflag;
void init()
{
memset(mp,0,sizeof(mp));
memset(vis,0,sizeof(vis));
retflag = 0;
wall = 0;
}
void dfs(int x,int y,int step)
{
if(x == ex && y == ey)
{
if(step == t)
{
retflag = 1;
}
return;
}
if(retflag)return;
int temp = (t - step) - (abs(sx - ex) + abs(sy - ey));
if(temp < 0 || temp & 1)
{
return;
}
for(int i = 0;i < 4;i++)
{
int nx = x + foot[i][0];
int ny = y + foot[i][1];
if(nx >= 0 && nx < n && ny >= 0 && ny < m && !vis[nx][ny] && mp[nx][ny] != 1)
{
vis[nx][ny] = 1;
dfs(nx,ny,step + 1);
vis[nx][ny] = 0;
}
}
} int main()
{
char ch;
while(~scanf("%d%d%d",&n,&m,&t))
{
getchar();
if(!n && !m && !t)break;
init();
for(int i = 0;i < n;i++)
{
for(int j = 0;j < m;j++)
{
scanf("%c",&ch);
if(ch=='X'){mp[i][j] = 1;wall++;}
if(ch=='S')
{
sx = i;
sy = j;
vis[i][j] = 1;
}
if(ch=='D')
{
ex = i;
ey = j;
}
if(ch=='.')mp[i][j] = 0;
}
getchar();
}
if(n * m - wall <= t)
{
printf("NO\n");
continue;
}
dfs(sx,sy,0);
if(retflag)printf("YES\n");
else printf("NO\n");
}
return 0;
}

DFS剪枝处理HDU1010的更多相关文章

  1. *HDU1455 DFS剪枝

    Sticks Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Subm ...

  2. POJ 3009 DFS+剪枝

    POJ3009 DFS+剪枝 原题: Curling 2.0 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 16280 Acce ...

  3. poj 1724:ROADS(DFS + 剪枝)

    ROADS Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10777   Accepted: 3961 Descriptio ...

  4. DFS(剪枝) POJ 1011 Sticks

    题目传送门 /* 题意:若干小木棍,是由多条相同长度的长木棍分割而成,问最小的原来长木棍的长度: DFS剪枝:剪枝搜索的好题!TLE好几次,终于剪枝完全! 剪枝主要在4和5:4 相同长度的木棍不再搜索 ...

  5. DFS+剪枝 HDOJ 5323 Solve this interesting problem

    题目传送门 /* 题意:告诉一个区间[L,R],问根节点的n是多少 DFS+剪枝:父亲节点有四种情况:[l, r + len],[l, r + len - 1],[l - len, r],[l - l ...

  6. HDU 5952 Counting Cliques 【DFS+剪枝】 (2016ACM/ICPC亚洲区沈阳站)

    Counting Cliques Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

  7. HDU 5937 Equation 【DFS+剪枝】 (2016年中国大学生程序设计竞赛(杭州))

    Equation Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...

  8. LA 6476 Outpost Navigation (DFS+剪枝)

    题目链接 Solution DFS+剪枝 对于一个走过点k,如果有必要再走一次,那么一定是走过k后在k点的最大弹药数增加了.否则一定没有必要再走. 记录经过每个点的最大弹药数,对dfs进行剪枝. #i ...

  9. poj 1011 Sticks (DFS+剪枝)

    Sticks Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 127771   Accepted: 29926 Descrip ...

随机推荐

  1. ubuntu 安装 selenium selenium操作 chrome

    重装虚拟机,好多包需要重装,sele这个记得当时就找了好久的完整重装方法,这次又找了好久,,,省的下次再这样,记录下来..... ubuntu16.04 4安装seleniumsudo pip ins ...

  2. Unknown column in 'field list'

    好久都没有亲手写数据库的连接以及操作了,近期一直都是用ejb,直接就映射到数据库了,所以关于jdbc的知识都忘得差不多了.不过吧,为了学习struts2,还是重新将jdbc知识捡起来.找了一上午的错误 ...

  3. sass使用指南

    [sass使用指南] http://www.ruanyifeng.com/blog/2012/06/sass.html

  4. C语言实现大数四则运算

    一.简介 众所周知,C语言中INT类型是有限制,不能进行超过其范围的运算,而如果采用float类型进行运算,由于float在内存中特殊的存储形式,又失去了计算的进度.要解决整个问题,一种解决方法是通过 ...

  5. ubuntu的文本界面修改字体大小

    使用命令: dpkg-reconfigure console-setup

  6. Url,HTTPUrlConnection(一)

    package com.cmy.urlcon; import java.io.BufferedReader; import java.io.IOException; import java.io.In ...

  7. 【校招面试 之 C/C++】第13题 C++ 指针和引用的区别

    1.指针和引用的定义和性质区别: (1)指针:指针是一个变量,只不过这个变量存储的是一个地址,指向内存的一个存储单元:而引用跟原来的变量实质上是同一个东西,只不过是原变量的一个别名而已.如: int ...

  8. php下的原生ajax请求

    浏览器中为我们提供了一个JS对象XMLHttpRequet,它可以帮助我们发送HTTP请求,并接受服务端的响应. 意味着我们的浏览器不提交,通过JS就可以请求服务器.   ajax(Asynchron ...

  9. JFinal架构简介

    JFinal 是基于Java 语言的极速 web 开发框架,其核心设计目标是开发迅速.代码量少.学习简单.功能强大.轻量级.易扩展.Restful.在拥有Java语言所有优势的同时再拥有ruby.py ...

  10. Spring框架的JDBC模板技术概述

    1. Spring框架中提供了很多持久层的模板类来简化编程,使用模板类编写程序会变的简单 2. 提供了JDBC模板,Spring框架提供的 * JdbcTemplate类 3. Spring框架可以整 ...