UVA 10047 The Monocycle
大白图论第二题···
题意:独轮车的轮子被均分成五块,每块一个颜色,每走过一个格子恰好转过一个颜色。



在一个迷宫中,只能向前走或者左转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的更多相关文章
- 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 ...
- UVA 10047 - The Monocycle BFS
http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...
- uva 10047 The Monocycle(搜索)
好复杂的样子..其实就是纸老虎,多了方向.颜色两个状态罢了,依旧是bfs. 更新的时候注意处理好就行了,vis[][][][]要勇敢地开. 不过这个代码交了十几遍的submission error,手 ...
- UVA 11624 UVA 10047 两道用 BFS进行最短路搜索的题
很少用bfs进行最短路搜索,实际BFS有时候挺方便得,省去了建图以及复杂度也降低了O(N*M): UVA 11624 写的比较挫 #include <iostream> #include ...
- UVa 10047,独轮车
题目链接:https://uva.onlinejudge.org/external/100/10047.pdf 题目链接:http://vjudge.net/contest/132239#proble ...
- UVa (BFS) The Monocycle
题目不光要求要到达终点而且要求所走的步数为5的倍数,每个时刻有三个选择,前进,左转弯,右转弯. 所以在vis数组中新增加两个维度即可,vis[x][y][dir][color]表示在(x, y)格子方 ...
- uva 10047 the monocyle (四维bfs)
算法指南白书 维护一个四维数组,走一步更新一步 #include<cstdio> #include<cstring> #include<queue> #includ ...
- UVa 10047 自行车 状态记录广搜
每个格子(x,y,drection,color) #include<iostream> #include<cstdio> #include<cstring> #in ...
- UVA题目分类
题目 Volume 0. Getting Started 开始10055 - Hashmat the Brave Warrior 10071 - Back to High School Physics ...
随机推荐
- python的dict()函数
dict(one=1,two=2) dict({'one':1,'two':2}) dict((('one',1),('two',2))) dict((['one',1],['two',2])) di ...
- 被忽略却很有用的html标签
<base>标签 作用:标签为页面中所有链接指定默认链接地址或链接目标.有时候我们需要让首页的链接全部在新窗口中打开,我们一般会这样写链接,而使用这个标签就能一下搞定了! 属性:Href ...
- 安装eclipse for JavaEE 后的一些设置
以下的设置是相对于一个workspace而设置的,如果更换了workspace则要重新设置. 1. 设置Text Editors: 2. 设置Content Assist 的快捷键(比较方便) 3. ...
- 使用apt-fast 来加速你的Ubuntu 的apt
使用apt-fast 来加速你的Ubuntu 的apt sudo add-apt-repository ppa:apt-fast/stable sudo apt-get update sudo apt ...
- Mahout学习之Mahout简介、安装、配置、入门程序测试
一.Mahout简介 查了Mahout的中文意思——驭象的人,再看看Mahout的logo,好吧,想和小黄象happy地玩耍,得顺便陪陪这位驭象人耍耍了... 附logo: (就是他,骑在象头上的那个 ...
- 90. Subsets II
题目: Given a collection of integers that might contain duplicates, nums, return all possible subsets. ...
- Case Study: Random Number Generation(翻译教材)
很荣幸,经过三天的努力.终于把自己翻译的教材做完了,现在把它贴出来,希望能指出其中的不足. Case Study: Random Number Generation Fig. 6.7 C++ 标 ...
- 车牌识别LPR(二)-- 车牌特征及难点
第二篇:车牌的特征及难点 2.1 对我国车牌的认识 我国目前使用的汽车牌号标准是 2007 年开始实施的<中华人民共和国机动车号牌>GA36-2007(2010 年修订).根据 GA36 ...
- IOS代码
//// MJViewController.m// UITableView-编辑模式//// Created by mj on 13-4-11.// Copyright (c) 2013年 itcas ...
- 爬虫技术(六)-- 使用HtmlAgilityPack获取页面链接(附c#代码及插件下载)
菜鸟HtmlAgilityPack初体验...弱弱的代码... Html Agility Pack是一个开源项目,为网页提供了标准的DOM API和XPath导航.使用WebBrowser和HttpW ...