博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
洛谷——P1126 机器人搬重物
阅读量:6851 次
发布时间:2019-06-26

本文共 2606 字,大约阅读时间需要 8 分钟。

P1126 机器人搬重物

题目描述

机器人移动学会(RMI)现在正尝试用机器人搬运物品。机器人的形状是一个直径1.6米的球。在试验阶段,机器人被用于在一个储藏室中搬运货物。储藏室是一个N*M的网格,有些格子为不可移动的障碍。机器人的中心总是在格点上,当然,机器人必须在最短的时间内把物品搬运到指定的地方。机器人接受的指令有:向前移动1步(Creep);向前移动2步(Walk);向前移动3步(Run);向左转(Left);向右转(Right)。每个指令所需要的时间为1秒。请你计算一下机器人完成任务所需的最少时间。

输入输出格式

输入格式:

 

输入的第一行为两个正整数N,M(N,M<=50),下面N行是储藏室的构造,0表示无障碍,1表示有障碍,数字之间用一个空格隔开。接着一行有四个整数和一个大写字母,分别为起始点和目标点左上角网格的行与列,起始时的面对方向(东E,南S,西W,北N),数与数,数与字母之间均用一个空格隔开。终点的面向方向是任意的。

 

输出格式:

 

一个整数,表示机器人完成任务所需的最少时间。如果无法到达,输出-1。

 

输入输出样例

输入样例#1:
9 100 0 0 0 0 0 1 0 0 00 0 0 0 0 0 0 0 1 00 0 0 1 0 0 0 0 0 00 0 1 0 0 0 0 0 0 00 0 0 0 0 0 1 0 0 00 0 0 0 0 1 0 0 0 00 0 0 1 1 0 0 0 0 00 0 0 0 0 0 0 0 0 01 0 0 0 0 0 0 0 1 07 2 2 7 S
输出样例#1
12
 
 
真的是很不错的搜索题(泪奔、、、)
由于机器人是个恶心的圆形,那我们们在判断某个位置是否可以走的时候我们就需要判断这个圆形所占的位置是否可以走,然后在进行移动。
有一个很鬼畜的地方就是我们必须要向经行正面移动才能进行方向的转动,不然会wa好几个点
然后我们要用一个数组记录到当前点且为到当前方向是否已经到达过,如果已经到达过,直接continue,因为我们知道bfs首先到达的一定是最近的,这样我们就可以做到一个很好的剪枝
#include
#include
#include
#include
#include
#define N 100using namespace std;char ch;bool flag,vis[N][N],vist[N][N][5];int n,m,d,sx,sy,ex,ey,dis[N][N];int xx[4][3]={
{
0,0,0},{-1,-2,-3},{
0,0,0},{
1,2,3}};int yy[4][3]={
{-1,-2,-3},{
0,0,0},{
1,2,3},{
0,0,0}};int read(){ int x=0,f=1; char ch=getchar(); while(ch<'0'||ch>'9') ch=getchar(); while(ch>='0'&&ch<='9') x=x*10+ch-'0',ch=getchar(); return x*f;}struct Que{ int x,y,d,step;}que;queue
q;int main(){ n=read(),m=read(); for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) { vis[i][j]=read(); if(vis[i][j]) vis[i-1][j]=vis[i-1][j-1]=vis[i][j-1]=true; } sx=read(),sy=read(); ex=read(),ey=read(); cin>>ch;vis[sx][sy]=1; if(ch=='W') que.d=0; if(ch=='E') que.d=2; if(ch=='N') que.d=1; if(ch=='S') que.d=3; que.x=sx,que.y=sy; dis[sx][sy]=que.step=0; vist[sx][sy][que.d]=true; q.push(que); while(!q.empty()) { Que p=q.front();q.pop(); if(p.x==ex&&p.y==ey){ printf("%d",p.step); return 0;} for(int i=0;i<3;i++) { int x=p.x+xx[p.d][i],y=p.y+yy[p.d][i]; if(x<1||y<1||x>=n||y>=m||vis[x][y]) break; if(vist[x][y][p.d]) continue; vist[x][y][p.d]=true; que.x=x,que.y=y,que.d=p.d,que.step=p.step+1; q.push(que); } que.x=p.x,que.y=p.y,que.d=p.d+1,que.step=p.step+1; if(p.d+1==4) que.d=0; if(!vist[que.x][que.y][que.d]) vist[que.x][que.y][que.d]=true,q.push(que); que.x=p.x,que.y=p.y,que.d=p.d-1,que.step=p.step+1; if(p.d-1==-1) que.d=3; if(!vist[que.x][que.y][que.d]) vist[p.x][p.y][p.d]=true,q.push(que); } printf("-1"); return 0;}

 

转载于:https://www.cnblogs.com/z360/p/7602051.html

你可能感兴趣的文章
微信公众平台群发规则说明
查看>>
LINUX下直接使用ISO文件
查看>>
第四章 apache的工作模式
查看>>
mysql备份和恢复总结
查看>>
软件明明已经删除 控制面板里还有名称
查看>>
深入浅出的SQL server 查询优化
查看>>
Hyper-V vNext新的虚拟机配置文件、配置版本
查看>>
通俗易懂,各常用线程池的执行 流程图
查看>>
CentOS 6.4 安装python2.7/mysqldb/ipython
查看>>
hive0.11 hiveserver custom认证bug
查看>>
Windows Phone SDK 8.0 新特性-Speech
查看>>
VS~单步调试DLL
查看>>
MyEclipse环境下Hibernate入门实例
查看>>
VC+CSocket文件传送示例
查看>>
职业生涯中的选择时机非常重要,各种条件还没成熟时的时候,因为诱惑而贸然行事,只会得到适得其反的结果...
查看>>
[WebDevelopment]搜索引擎优化(SEO)工具包
查看>>
Symbian OS开发入门(二) :VS2003环境下Symbian工程的导入与建立
查看>>
RequiredFieldValidator 根据group组来触发验证
查看>>
[AR]ImageTarget(图像识别)
查看>>
[C++] socket -9[匿名管道]
查看>>