Description

The cornfield maze is a popular Halloween treat. Visitors are shown the entrance and must wander through the maze facing zombies, chainsaw-wielding psychopaths, hippies, and other terrors on their quest to find the exit. 

One popular maze-walking strategy guarantees that the visitor will eventually find the exit. Simply choose either the right or left wall, and follow it. Of course, there's no guarantee which strategy (left or right) will be better, and the path taken is seldom
the most efficient. (It also doesn't work on mazes with exits that are not on the edge; those types of mazes are not represented in this problem.) 

As the proprieter of a cornfield that is about to be converted into a maze, you'd like to have a computer program that can determine the left and right-hand paths along with the shortest path so that you can figure out which layout has the best chance of confounding
visitors.

Input

Input to this problem will begin with a line containing a single integer n indicating the number of mazes. Each maze will consist of one line with a width, w, and height, h (3 <= w, h <= 40), followed by h lines of w characters each that represent the maze
layout. Walls are represented by hash marks ('#'), empty space by periods ('.'), the start by an 'S' and the exit by an 'E'. 

Exactly one 'S' and one 'E' will be present in the maze, and they will always be located along one of the maze edges and never in a corner. The maze will be fully enclosed by walls ('#'), with the only openings being the 'S' and 'E'. The 'S' and 'E' will also
be separated by at least one wall ('#'). 

You may assume that the maze exit is always reachable from the start point.

Output

For each maze in the input, output on a single line the number of (not necessarily unique) squares that a person would visit (including the 'S' and 'E') for (in order) the left, right, and shortest paths, separated by a single space each. Movement from one
square to another is only allowed in the horizontal or vertical direction; movement along the diagonals is not allowed.

Sample Input

2
8 8
########
#......#
#.####.#
#.####.#
#.####.#
#.####.#
#...#..#
#S#E####
9 5
#########
#.#.#.#.#
S.......E
#.#.#.#.#
#########

Sample Output

37 5 5
17 17 9
这道题求最短路可以用bfs,但是求绕墙走的时间时不用搜索,因为一定只有唯一的一条路,绕墙走有优先考虑左边和右边两种情况,考虑左边的时候,如果能往左走就往做,否则再考虑能不能向前走,即按原来的方向,如果也不行,再看能不能往右走,如果三种情况都不行,就往后走,这里要开一个数组记录方向。
#include<stdio.h>
#include<string.h>
#include<math.h>
char map[45][45];
int tab[8][2]={0,0,0,1,-1,0,0,-1,1,0},dir,b[45][45];
int q[1111111][2],x3,y3,x2,y2,n,m; void bfs()
{
memset(q,0,sizeof(q));
memset(b,0,sizeof(b));
b[x2][y2]=1;
int front=1,rear=1,xx,yy,i,x,y;
q[front][0]=x2;q[front][1]=y2;
while(front<=rear){
x=q[front][0];
y=q[front][1];
if(x==x3 && y==y3)break;
front++;
for(i=1;i<=4;i++){
xx=x+tab[i][0];yy=y+tab[i][1];
if(xx>=0 && xx<m && yy>=0 && yy<n && map[xx][yy]!='#'){
map[xx][yy]='#';
b[xx][yy]=b[x][y]+1;
rear++;
q[rear][0]=xx;
q[rear][1]=yy;
}
}
}
return ;
} int main()
{
int T,i,j,num1,num2,num3,x,y,dir1,xx,yy,dir2;
scanf("%d",&T);
while(T--)
    {
    scanf("%d%d",&n,&m);
    for(i=0;i<m;i++){
    scanf("%s",map[i]);
    for(j=0;j<n;j++){
    if(map[i][j]=='S'){
    x2=i;y2=j;
    }
    else if(map[i][j]=='E'){
    x3=i;y3=j;
    }
    }
   }
   if(y2==1)dir=1;
   else if(x2==m)dir=2;
   else if(y2==n)dir=3;
   else if(x2==1)dir=4;
   num1=0;
   
   
   memset(b,0,sizeof(b));
   x=x2,y=y2,num1=1,dir1=dir;
   while(1)
   {
if(x==x3 && y==y3)break;
num1++;
//printf("%d %d\n",x+1,y+1);
    xx=x+tab[dir1%4+1][0];
    yy=y+tab[dir1%4+1][1];
if(xx>=0 && xx<m && yy>=0 && yy<n && map[xx][yy]!='#'){
    x=xx;y=yy;
dir1=dir1%4+1;continue;
   }
   
   xx=x+tab[dir1][0];
   yy=y+tab[dir1][1];
   if(xx>=0 && xx<m && yy>=0 && yy<n && map[xx][yy]!='#'){
    x=xx;y=yy;continue;
    }
   
    xx=x+tab[(dir1==1)?4:(dir1-1)][0];
    yy=y+tab[(dir1==1)?4:(dir1-1)][1];
    if(xx>=0 && xx<m && yy>=0 && yy<n && map[xx][yy]!='#'){
    x=xx;y=yy;
dir1=(dir1==1?4:(dir1-1));continue;
   }
   
   
   dir1=(dir1+1)%4+1;
   x=x+tab[dir1][0];
   y=y+tab[dir1][1];
   
    }
    //printf("%d\n",num1);
   
    memset(b,0,sizeof(b));
   x=x2,y=y2,num2=1,dir2=dir;
   while(1)
   {
   
if(x==x3 && y==y3)break;
num2++;
//printf("%d %d\n",x+1,y+1); xx=x+tab[(dir2==1)?4:(dir2-1)][0];
    yy=y+tab[(dir2==1)?4:(dir2-1)][1];
    if(xx>=0 && xx<m && yy>=0 && yy<n && map[xx][yy]!='#'){
    x=xx;y=yy;
dir2=(dir2==1?4:(dir2-1));continue;
   }
   
    xx=x+tab[dir2][0];
   yy=y+tab[dir2][1];
   if(xx>=0 && xx<m && yy>=0 && yy<n && map[xx][yy]!='#'){
    x=xx;y=yy;continue;
    }
   
xx=x+tab[dir2%4+1][0];
    yy=y+tab[dir2%4+1][1];
if(xx>=0 && xx<m && yy>=0 && yy<n && map[xx][yy]!='#'){
    x=xx;y=yy;
dir2=dir2%4+1;continue;
   }
   dir2=(dir2+1)%4+1;
   x=x+tab[dir2][0];
   y=y+tab[dir2][1];
   
    }
    map[x2][y2]='#';
   bfs();
   num3=b[x3][y3];
   printf("%d %d %d\n",num1,num2,num3);
    }
    return 0;
}

poj3083 Children of the Candy Cor的更多相关文章

  1. POJ3083——Children of the Candy Corn(DFS+BFS)

    Children of the Candy Corn DescriptionThe cornfield maze is a popular Halloween treat. Visitors are ...

  2. poj3083 Children of the Candy Corn BFS&&DFS

    Children of the Candy Corn Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 11215   Acce ...

  3. POJ3083 Children of the Candy Corn(搜索)

    题目链接. 题意: 先沿着左边的墙从 S 一直走,求到达 E 的步数. 再沿着右边的墙从 S 一直走,求到达 E 的步数. 最后求最短路. 分析: 最短路好办,关键是沿着墙走不太好想. 但只要弄懂如何 ...

  4. POJ3083 Children of the Candy Corn(Bfs + Dfs)

    题意:给一个w*h的迷宫,其中矩阵里面 S是起点,E是终点,“#”不可走,“.”可走,而且,S.E都只会在边界并且,不会在角落,例如(0,0),输出的话,每组数据就输出三个整数,第一个整数,指的是,以 ...

  5. POJ-3083 Children of the Candy Corn (BFS+DFS)

    Description The cornfield maze is a popular Halloween treat. Visitors are shown the entrance and mus ...

  6. poj3083 Children of the Candy Corn 深搜+广搜

    这道题有深搜和广搜.深搜还有要求,靠左或靠右.下面以靠左为例,可以把简单分为上北,下南,左西,右东四个方向.向东就是横坐标i不变,纵坐标j加1(i与j其实就是下标).其他方向也可以这样确定.通过上一步 ...

  7. poj 3083 Children of the Candy Corn

    点击打开链接 Children of the Candy Corn Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8288 ...

  8. Children of the Candy Corn 分类: POJ 2015-07-14 08:19 7人阅读 评论(0) 收藏

    Children of the Candy Corn Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10933   Acce ...

  9. POJ 3083 Children of the Candy Corn bfs和dfs

      Children of the Candy Corn Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8102   Acc ...

随机推荐

  1. Neo4j 图数据库查询

    Cypher 介绍 Cypher 介绍:作为Neo4j的查询语言,"Cypher"是一个描述性的图形查询语言,允许不必编写图形结构的遍历代码对图形存储有表现力和效率的查询.Cyph ...

  2. 一道有趣的golang排错题

    很久没写博客了,不得不说go语言爱好者周刊是个宝贝,本来想随便看看打发时间的,没想到一下子给了我久违的灵感. go语言爱好者周刊78期出了一道非常有意思的题目. 我们来看看题目.先给出如下的代码: p ...

  3. MySQL where 条件字句查询

    where 条件字句 搜索条件可由一个或多个逻辑表达式组成 , 结果一般为布尔值 逻辑运算符 运算符 语法 描述 and && a and b a && b 逻辑与 两 ...

  4. innodb日志文件大小

    innodb是用多个文件作为一组循环日志,通常不需要修改默认的日志数量,只修改每个日志文件的大小即可,要修改日志文件大小,需要完全关闭mysql,将旧的日志文件移到其他地方保存,重新配置参数,然后重启 ...

  5. git创建分支并关联远程分支

    1.新建本地分支: 如图,再输入你的分支名字,然后选择从哪个远程分支拉代码,如选择master 至此本地分支创建完成. 2.关联远程分支: (1).先输入git branch -vv,看看分支与远程分 ...

  6. 容器编排系统K8s之包管理器helm基础使用(二)

    前文我们介绍了helm的相关术语和使用helm安装和卸载应用,回顾请参考:https://www.cnblogs.com/qiuhom-1874/p/14305902.html:今天我们来介绍下自定义 ...

  7. 与图论的邂逅06:dfs找环

    当我在准备做基环树的题时,经常有了正解的思路确发现不会找环,,,,,,因为我实在太蒻了. 所以我准备梳理一下找环的方法: 有向图 先维护一个栈,把遍历到的节点一个个地入栈.当我们从一个节点x回溯时无非 ...

  8. 解决Python内CvCapture视频文件格式不支持问题

    解决Python内CvCapture视频文件格式不支持问题 在读取视频文件调用默认的摄像头cv.VideoCapture(0)会出现下面的视频格式问题 CvCapture_MSMF::initStre ...

  9. ElasticSearch Python 基本操作

    创建索引 from elasticsearch import Elasticsearch es = Elasticsearch('192.168.149.96:9200') mappings = { ...

  10. 不错的网站压力测试工具webbench

    webbench最多可以模拟3万个并发连接去测试网站的负载能力,个人感觉要比Apache自带的ab压力测试工具好,安装使用也特别方便. 1.适用系统:Linux 2.前期准备:yum install ...