https://www.luogu.org/problem/show?pid=1126

题目描述

机器人移动学会(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

搜索入门中,ε=(´ο`*))),麻烦又恶心,广搜每次每种走法、
注意的几点:黑格子的左侧,左上,上方的格子都不能去,(意会一下),
如果某个点相当前方向不能走i步,则一定不能走i+1步,已经被阻断。
方向改变多模拟几次、
 #include <cstdio>
#include <queue> bool vis[][][];
int n,m,map[][];
int arrivex,arrivey;
int fx[]={-,,,};
int fy[]={,-,,};
struct Node_pos {
int x,y,step;
int direction;
}now;
std::queue<Node_pos>que; inline bool can_go(Node_pos now)
{
if(now.x>=n||now.y>=m||now.x<||now.y<) return false;
if(vis[now.x][now.y][now.direction]||vis[now.x+][now.y+][now.direction]) return ;
if(vis[now.x+][now.y][now.direction]||vis[now.x][now.y+][now.direction]) return ;
if(map[now.x][now.y]||map[now.x+][now.y]||map[now.x][now.y+]||map[now.x+][now.y+]) return ;
return true;
} inline void read(int &x)
{
x=; register char ch=getchar();
for(;ch>''||ch<'';) ch=getchar();
for(;ch>=''&&ch<='';ch=getchar()) x=x*+ch-'';
} int AC()
{
read(n),read(m);
for(int x,i=; i<=n; ++i)
for(int j=; j<=m; ++j)
{
read(map[i][j]);
if(map[i][j]) map[i][j-]=map[i-][j]=map[i-][j-]=;
}
read(now.x);read(now.y);
read(arrivex);read(arrivey);
char s[];scanf("%s",s);
switch (s[]) {
case 'N': now.direction=;break;
case 'W': now.direction=;break;
case 'S': now.direction=;break;
case 'E': now.direction=;break;
}
que.push(now);
vis[now.x][now.y][now.direction]=;
for(Node_pos to;!que.empty();)
{
to=now=que.front(); que.pop(); // printf("%d %d\n",now.x,now.y); if(now.x==arrivex&&now.y==arrivey)
{ printf("%d\n",now.step); return ; }
for(int i=; i<; ++i)
{
to.x+=fx[now.direction];
to.y+=fy[now.direction];
if(map[to.x][to.y]||to.x<||to.y<||to.x>=n||to.y>=m) break;
// if(!can_go(to)) break;
to.step=now.step+;
// vis[to.x+1][to.y][now.direction]=1;
// vis[to.x][to.y+1][now.direction]=1;
// vis[to.x+1][to.y+1][now.direction]=1; if(to.x==arrivex&&to.y==arrivey)
{ printf("%d\n",to.step); return ; }
else if(!vis[to.x][to.y][now.direction])
{
vis[to.x][to.y][now.direction]=;
que.push(to);
}
} to=now;
if(!vis[now.x][now.y][now.direction+&])
{
to.direction=now.direction+&;
vis[to.x][to.y][to.direction]=;
to.step=now.step+; que.push(to);
}
if(!vis[now.x][now.y][now.direction+&])
{
to.direction=now.direction+&;
vis[to.x][to.y][to.direction]=;
to.step=now.step+; que.push(to);
}
} puts("-1");
return ;
} int Hope=AC();
int main(){;}

洛谷—— P1126 机器人搬重物的更多相关文章

  1. 洛谷P1126 机器人搬重物

    洛谷1126 机器人搬重物 题目描述 机器人移动学会(RMI)现在正尝试用机器人搬运物品.机器人的形状是一个直径1.6米的球.在试验阶段,机器人被用于在一个储藏室中搬运货物.储藏室是一个N*M的网格, ...

  2. 洛谷——P1126 机器人搬重物

    P1126 机器人搬重物 题目描述 机器人移动学会(RMI)现在正尝试用机器人搬运物品.机器人的形状是一个直径1.6米的球.在试验阶段,机器人被用于在一个储藏室中搬运货物.储藏室是一个N*M的网格,有 ...

  3. 洛谷 P1126 机器人搬重物 (BFS)

    题目链接:https://www.luogu.org/problemnew/show/P1126 吐槽:这题很阴险 一开始没把格子图转化成点图:30分 转化成点图,发现样例过不去,原来每步要判断vis ...

  4. 洛谷P1126 机器人搬重物【bfs】

    题目链接:https://www.luogu.org/problemnew/show/P1126 题意: 给定一个n*m的方格,机器人推着直径是1.6的球在格子的线上运动. 每一秒钟可以向左转,向右转 ...

  5. 洛谷P1126机器人搬重物[BFS]

    题目描述 机器人移动学会(RMI)现在正尝试用机器人搬运物品.机器人的形状是一个直径1.6米的球.在试验阶段,机器人被用于在一个储藏室中搬运货物.储藏室是一个N*M的网格,有些格子为不可移动的障碍.机 ...

  6. 洛谷 P1126 机器人搬重物

    题目描述 机器人移动学会(RMI)现在正尝试用机器人搬运物品.机器人的形状是一个直径 $1.6 米的球.在试验阶段,机器人被用于在一个储藏室中搬运货物.储藏室是一个 N×MN \times MN×M ...

  7. luogu P1126 机器人搬重物 题解

    luogu P1126 机器人搬重物 题解 题目描述 机器人移动学会(\(RMI\))现在正尝试用机器人搬运物品.机器人的形状是一个直径\(1.6\)米的球.在试验阶段,机器人被用于在一个储藏室中搬运 ...

  8. P1126 机器人搬重物

    P1126 机器人搬重物 题目描述 机器人移动学会(RMI)现在正尝试用机器人搬运物品.机器人的形状是一个直径1.6米的球.在试验阶段,机器人被用于在一个储藏室中搬运货物.储藏室是一个N*M的网格,有 ...

  9. luogu P1126 机器人搬重物

    题目描述 机器人移动学会(RMI)现在正尝试用机器人搬运物品.机器人的形状是一个直径1.6米的球.在试验阶段,机器人被用于在一个储藏室中搬运货物.储藏室是一个N*M的网格,有些格子为不可移动的障碍.机 ...

随机推荐

  1. Xamarin Mono For Android、Monotouch 安装

    一.Windows下面的安装 1. 安装环境介绍:    Win8.1 企业版64位或Win7 64.VS2013 update4 2. 安装jdk    到oracle官方下载jdk-8u45-wi ...

  2. luogu2518 [HAOI2010] 计数

    题目大意 给出一个数字$n$,求满足下列条件的数$x$的个数: $x<n$ 对于来自于$x$十进制各个数位上的非零数字,它们的种类与个数都与$n$的相同. 思路 入手点 设$n$有$t$位数字, ...

  3. bzoj4247: 挂饰(背包)

    4247: 挂饰 题目:传送门 题解: 看完题目很明显的一道二维背包(一开始还推错了) 设f[i][j]表示前i个挂饰选完(可以有不选)之后还剩下j个挂钩的最大值(j最多贡献为n) 那么f[i][j] ...

  4. hdoj--1083--Courses(最大匹配)

    Courses Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total ...

  5. [Database] 列出MSSQL所有数据库名、所有表名、所有字段名

    1.获取所有数据库名 Select Name From Master..SysDatabases order By Name 2.获取所有表名 Select Name From SysObjects ...

  6. MongoDB Master-Slave cluster with authentication setup

    Master Server create mongo db folder with sub folders like data, conf, && log mkdir -p /opt/ ...

  7. VS中的路径宏

    说明$(RemoteMachine)设置为“调试”属性页上“远程计算机”属性的值.有关更多信息,请参见更改用于 C/C++ 调试配置的项目设置.$(References)以分号分隔的引用列表被添加到项 ...

  8. MapReduce架构与生命周期

    MapReduce架构与生命周期 概述:MapReduce是hadoop的核心组件之一,可以通过MapReduce很容易在hadoop平台上进行分布式的计算编程.本文组织结果如下:首先对MapRedu ...

  9. 利用javascript(自定义事件)记录尺寸可变元素的尺寸变化过程

    1.效果图 2.源码 <%@ page contentType="text/html;charset=UTF-8" language="java" %&g ...

  10. django 安装运行

    pip install django pip list 查看版本 python -m django --version 新建django django-admin startproject mysit ...