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 10 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 1 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 1 0 7 2 2 7 S
输出样例#1
12
真的是很不错的搜索题(泪奔、、、)
由于机器人是个恶心的圆形,那我们们在判断某个位置是否可以走的时候我们就需要判断这个圆形所占的位置是否可以走,然后在进行移动。
有一个很鬼畜的地方就是我们必须要向经行正面移动才能进行方向的转动,不然会wa好几个点
然后我们要用一个数组记录到当前点且为到当前方向是否已经到达过,如果已经到达过,直接continue,因为我们知道bfs首先到达的一定是最近的,这样我们就可以做到一个很好的剪枝
#include<queue> #include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #define N 100 using 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<Que>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; }
时间: 2024-10-20 12:49:16