题目链接:

  http://poj.org/problem?id=2632

题目描述:

  有一个B*A的厂库,分布了n个机器人,机器人编号1~n。我们知道刚开始时全部机器人的位置和朝向,我们可以按顺序操控机器人,没有两个机器人可以同时执行命令。如果机器人走到厂库边界,他将碰到墙,如果两个机器人走到同一位置,则表示他们两个相撞。问m个命令内最先发生的碰撞,如果没有碰撞输出“OK”。

解题思路:

  由图可知,本题的矩阵与平时的不太一样,所以我们在对厂库进行操作的时候,可以先把厂库顺时针旋转90°,当然,方向也要跟着旋转90°。左右方向是不会跟着变的。然后老老实实的按照命令去模拟,就大功告成啦。

代码:

 #include <cstdio>
#include <cstring>
#include <cstdlib>
#include <iostream>
using namespace std; #define maxn 105 struct node
{
int x, y, s;
} stu[maxn];//每个机器人的位置(x,y),和方向s int dir[][] = {-,, ,, ,, ,-};//翻转后的四个方向:W,N,E,S
int map[maxn][maxn]; int main()
{
int t, A, B, n, m, i, j, flag, x, y, num1, num2;
char ch[]; scanf ("%d", &t);
while (t --)
{
flag = ;//是否发生碰撞
scanf ("%d %d", &A, &B);
scanf ("%d %d", &n, &m);
memset (map, , sizeof(map));
for (i=; i<=n; i++)
{
scanf ("%d %d %s", &stu[i].x, &stu[i].y, ch);
if (ch[] == 'W')
stu[i].s = ;
else if (ch[] == 'N')
stu[i].s = ;
else if (ch[] == 'E')
stu[i].s = ;
else
stu[i].s = ;
map[stu[i].x][stu[i].y] = i;
} while (m --)
{
scanf ("%d%s%d", &x, ch, &y);
if (flag)
continue;
if (ch[] == 'L')//对机器人进行转弯
{
stu[x].s -= y % ;//这里有可能是负数,会导致下面运行re,必须要处理
stu[x].s = (stu[x].s + ) % ;
}
else if (ch[] == 'R')
}
stu[x].s += y;
stu[x].s = (stu[x].s + ) % ;
}
else
{
map[stu[x].x][stu[x].y] = ;
while (y --)//一定要对沿途经过的地方进行判断,是否会有碰撞发生
{
stu[x].x = stu[x].x + dir[stu[x].s][];
stu[x].y = stu[x].y + dir[stu[x].s][];
if (stu[x].x<= || stu[x].x>A || stu[x].y<= || stu[x].y>B)//是否碰撞到墙
{
num1 = x;
flag = ;
break;
}
else if (map[stu[x].x][stu[x].y])//是否碰撞到别的机器人
{
num1 = x;
num2 = map[stu[x].x][stu[x].y];
flag = ;
break;
}
}
map[stu[x].x][stu[x].y] = x;
}
}
if (! flag)
printf ("OK\n");
else if (flag == )
printf ("Robot %d crashes into the wall\n", num1);
else
printf ("Robot %d crashes into robot %d\n", num1, num2);
}
return ;
}

  

poj 2632 Crashing Robots 模拟的更多相关文章

  1. POJ 2632 Crashing Robots (模拟 坐标调整)(fflush导致RE)

    题目链接:http://poj.org/problem?id=2632 先话说昨天顺利1Y之后,直到今天下午才再出题 TAT,真是刷题计划深似海,从此AC是路人- - 本来2632是道略微恶心点的模拟 ...

  2. POJ 2632 Crashing Robots 模拟 难度:0

    http://poj.org/problem?id=2632 #include<cstdio> #include <cstring> #include <algorith ...

  3. 模拟 POJ 2632 Crashing Robots

    题目地址:http://poj.org/problem?id=2632 /* 题意:几个机器人按照指示,逐个朝某个(指定)方向的直走,如果走过的路上有机器人则输出谁撞到:如果走出界了,输出谁出界 如果 ...

  4. POJ 2632 Crashing Robots (坑爹的模拟题)

    Crashing Robots Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6599   Accepted: 2854 D ...

  5. poj 2632 Crashing Robots(模拟)

    链接:poj 2632 题意:在n*m的房间有num个机器,它们的坐标和方向已知,现给定一些指令及机器k运行的次数, L代表机器方向向左旋转90°,R代表机器方向向右旋转90°,F表示前进,每次前进一 ...

  6. poj 2632 Crashing Robots

    点击打开链接 Crashing Robots Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6655   Accepted: ...

  7. POJ 2632 Crashing Robots(较为繁琐的模拟)

    题目链接:http://poj.org/problem?id=2632 题目大意:题意简单,N个机器人在一个A*B的网格上运动,告诉你机器人的起始位置和对它的具体操作,输出结果: 1.Robot i ...

  8. poj 2632 Crashing Robots_模拟

    做的差点想吐,调来调去,编译器都犯毛病,wlgq,幸好1a. 题意:给你机器人怎走的路线,碰撞就输出 #include <cstdlib> #include <iostream> ...

  9. Poj OpenJudge 百练 2632 Crashing Robots

    1.Link: http://poj.org/problem?id=2632 http://bailian.openjudge.cn/practice/2632/ 2.Content: Crashin ...

随机推荐

  1. 集群FULL GC导致服务不可用

    FULL GC会导致stop-the-world,频繁的FULL GC会影响系统的可用性.stackoverflow上有个提问是这么描述这个问题的:当服务器集群批量启动后,执行FULL GC的频率和时 ...

  2. 深度学习综述(LeCun、Bengio和Hinton)

    原文摘要:深度学习可以让那些拥有多个处理层的计算模型来学习具有多层次抽象的数据的表示.这些方法在很多方面都带来了显著的改善,包含最先进的语音识别.视觉对象识别.对象检測和很多其他领域,比如药物发现和基 ...

  3. 配置Python 2.7.1外加环境pywin32-216.win32-py2.7

    python-2.7.1  安装包 下载地址:http://download.csdn.net/detail/baidu_14854543/7985187 pywin32-216.win32-py2. ...

  4. Deepin-安装和卸载软件

    一般默认厂商源安装软件 安装软件: 示例:sudo apt-get install xx 实例:sudo apt-get install nodejs 卸载软件: 示例:sudo apt-get -- ...

  5. &lt;Android&gt;greenrobot-EventBus,guava-Event Bus的异步实现

    刚開始是从otto入手,可是otto不支持异步运行.所以后来才開始研究了Event Bus.关于Event Bus,先前搜索的时候,看到网上的实例,非常碎,并且非常多都是一样的内容,代码看下来基本上是 ...

  6. 暴力破解zip文件

    #coding=utf-8 """ 用户输入-z参数指定要破解的zip文件,输入-d参数输入字典文件,即可暴力破解加密的zip文件 """ ...

  7. iPhone开发关于UDID和UUID的一些理解【转】

    原文地址:http://blog.csdn.net/xunyn/article/details/13629071 一.UDID(Unique Device Identifier) UDID是Uniqu ...

  8. myeclipse配置hadoop开发环境

    1.安装Hadoop开发插件 hadoop安装包contrib/目录下有个插件hadoop-0.20.2-eclipse-plugin.jar,拷贝到myeclipse根目录下/dropins目录下. ...

  9. 请说出作用域public,private,protected,以及不写时的区别

    这四个作用域的可见范围如下表所示. 说明:如果在修饰的元素上面没有写任何访问修饰符,则表示friendly. 作用域    当前类 同一package 子孙类 其他package public    ...

  10. JavaScript语言基础4

    谈谈JavaScript 中的变量. 在JavaScript 中使用变量的优点:变量保存在计算机的内存中,变量很适合于保存暂时性的数据 ,变量仅仅具有有限的生存期,当 用户关闭了页面或者打开一个新的页 ...