大白图论第二题···

题意:独轮车的轮子被均分成五块,每块一个颜色,每走过一个格子恰好转过一个颜色。

在一个迷宫中,只能向前走或者左转90度或右转90度(我曾天真的认为是向左走和向右走···),每个操作的时间是1s。

在起点轮子的绿色块着地,方向向北,要求到终点时同样是绿色块着地,方向不限,求最短时间,若走不到输出”destination not reachable“。每个样例中间空一行(没错我又因为这个wa了···uva上竟然没有pe···【捂脸跑开】)

解法:BFS。visit数组多加两维记录方向和颜色,dir数组从北开始按顺时针或逆时针存,当下标的奇偶性和当前方向不同时为向左右转,当到达终点并颜色为起始颜色时得到答案。

代码:

#include<stdio.h>
#include<iostream>
#include<algorithm>
#include<string>
#include<string.h>
#include<math.h>
#include<map>
#include<queue>
#define ll long long
using namespace std;
struct node
{
int x,y,d,c,step;//横纵坐标,方向,颜色,时间
node(int x,int y,int d,int c,int step):x(x),y(y),d(d),c(c),step(step) {}
node() {}
};
int dir[4][2]= {-1,0,0,1,1,0,0,-1};//顺时针存,一维下标奇偶性相同的为相对的两个方向
int main()
{
int cnt=1;
int n,m;
while(~scanf("%d%d",&n,&m)&&!(n==0&&m==0))
{
int stx,sty;
string maze[30];
for(int i=0; i<n; i++)
{
cin>>maze[i];
for(int j=0; j<m; j++)
if(maze[i][j]=='S')
{
stx=i;
sty=j;//记录起始点
}
}
int visit[30][30][4][5]= {0};//横纵坐标,方向,颜色
queue<node> q;
q.push(node(stx,sty,0,0,0));
visit[stx][sty][0][0]=1;
int ans=-1;
while(!q.empty())
{
node temp=q.front();
q.pop();
if(maze[temp.x][temp.y]=='T'&&temp.c==0)
{
ans=temp.step;
break;
}
for(int i=0; i<4; i++)
{
if(!((i!=temp.d)&&((i&1)==(temp.d&1))))//判断反向是否合法【看起来写屎了···
{
int tx=temp.x+dir[i][0],ty=temp.y+dir[i][1];
if(i==temp.d)//直走的情况
{
if(tx>=0&&tx<n&&ty>=0&&ty<m&&maze[tx][ty]!='#'&&!visit[tx][ty][i][(temp.c+1)%5])
{
q.push(node(tx,ty,i,(temp.c+1)%5,temp.step+1));
visit[tx][ty][i][(temp.c+1)%5]=1;
}
}
else//转弯的情况
{
if(!visit[temp.x][temp.y][i][temp.c])
{
visit[temp.x][temp.y][i][temp.c]=1;
q.push(node(temp.x,temp.y,i,temp.c,temp.step+1));
}
}
}
}
}
if(cnt!=1)
puts("");//【吐槽】再次被坑
printf("Case #%d\n",cnt++);
if(ans!=-1)
printf("minimum time = %d sec\n",ans);
else
puts("destination not reachable");
}
return 0;
}

代码丑···见谅

UVA 10047 The Monocycle的更多相关文章

  1. UVA 10047 The Monocycle (状态记录广搜)

    Problem A: The Monocycle  A monocycle is a cycle that runs on one wheel and the one we will be consi ...

  2. UVA 10047 - The Monocycle BFS

    http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...

  3. uva 10047 The Monocycle(搜索)

    好复杂的样子..其实就是纸老虎,多了方向.颜色两个状态罢了,依旧是bfs. 更新的时候注意处理好就行了,vis[][][][]要勇敢地开. 不过这个代码交了十几遍的submission error,手 ...

  4. UVA 11624 UVA 10047 两道用 BFS进行最短路搜索的题

    很少用bfs进行最短路搜索,实际BFS有时候挺方便得,省去了建图以及复杂度也降低了O(N*M): UVA 11624 写的比较挫 #include <iostream> #include ...

  5. UVa 10047,独轮车

    题目链接:https://uva.onlinejudge.org/external/100/10047.pdf 题目链接:http://vjudge.net/contest/132239#proble ...

  6. UVa (BFS) The Monocycle

    题目不光要求要到达终点而且要求所走的步数为5的倍数,每个时刻有三个选择,前进,左转弯,右转弯. 所以在vis数组中新增加两个维度即可,vis[x][y][dir][color]表示在(x, y)格子方 ...

  7. uva 10047 the monocyle (四维bfs)

    算法指南白书 维护一个四维数组,走一步更新一步 #include<cstdio> #include<cstring> #include<queue> #includ ...

  8. UVa 10047 自行车 状态记录广搜

    每个格子(x,y,drection,color) #include<iostream> #include<cstdio> #include<cstring> #in ...

  9. UVA题目分类

    题目 Volume 0. Getting Started 开始10055 - Hashmat the Brave Warrior 10071 - Back to High School Physics ...

随机推荐

  1. call,apply,bind方法的总结

    why?call,apply,bind干什么的?为什么要学这个? 一般用来指定this的环境,在没有学之前,通常会有这些问题. var a = { user:"追梦子", fn:f ...

  2. ASP.NET 免费开源控件

    AspNetPager分页控件(当前版本:7.5.1) AspNetPager分页控件是应用于ASP.NET WebForm网站或应用程序中的自定义分页控件,支持默认的回发(Postback)分页和U ...

  3. CTSC2016&&APIO2016游记

    4.30 下午衡中放假,我们因为比赛的缘故提前到中午12:00放假 然后我爸爸说要来接我,直到下午两点多他才到,然后衡中宿舍的楼管阿姨死活不给我开门 莫名其妙的等到了三点多快四点的时候我才跟实验班的一 ...

  4. 【Linux高频命令专题(1)】sort

    介绍 sort命令是帮我们依据不同的数据类型进行排序,其语法及常用参数格式: sort [-bcfMnrtk][源文件][-o 输出文件] 补充说明:sort可针对文本文件的内容,以行为单位来排序. ...

  5. python 时间处理(time和datetime介绍)

    python的有关时间的有哪几种呢?今天我们介绍两个:time和datetime time模块提供各种操作时间的函数 datetime模块定义了下面这几个类: datetime.date:表示日期的类 ...

  6. 编译器的未来——我们还需要C++么?

    在未来我们还需要纯C++开发模式么? 随着C++11的诞生,C++已经越来越臃肿,从03的时候就觉得C++实在是太复杂了.以一个合格C++程序员的标准来简单的来说3-5年略有小成,5-8年才可以说自己 ...

  7. Android:PopupWindow简单弹窗

    两布局,一个当前布局页面和一个点击展示布局页面,主程序代码: public class MainActivity extends Activity { private PopupWindow pop; ...

  8. Windows系统上如何使用SSH

    Windows系统上如何使用SSH 传统的网络服务程序如FTP.Telnet等,在网络上一般使用明文传送数据.用户账号和口令信息,容易受到中间人的攻击.用户利用SSH协议后能有效防止DNS及IP欺骗, ...

  9. Quartz动态添加、修改和删除定时任务

    任务调度开源框架Quartz动态添加.修改和删除定时任务 Quartz 是个开源的作业调度框架,为在 Java 应用程序中进行作业调度提供了简单却强大的机制.Quartz框架包含了调度器监听.作业和触 ...

  10. C++:向函数传递对象(对象、对象指针、对象引用)

    3.5.1   使用对象作为函数参数,其方法与传递基本类型的变量相同 //例3.21 使用对象作为函数参数 #include<iostream> using namespace std; ...