题目传送门

本题知识点:模拟

模拟机器人的运作过程,分别有三种功能,L 则是左转90°,R 则是右转90°,L 则是前进1格。让我们去模拟并判断它们的状态。

输入:

第一行是测试样例

第二行分别是矩形的长、宽(比如,5 4)

// 题目是讲得很清楚的
// 4
// 3
// 2
// 1
// 1 2 3 4 5

第三行分别是机器人的个数以及指令条数

接下来是先输入每个机器人的初始状态(有多少个机器人就多少行),3个数值分别对应机器人所在位置的(x, y)以及机器人所面向的方向(因为 F 指令只能让机器人向前,所以懂得东南西北是很重要的一件事)

同样,接下来有多少条指令就输入多少行,3个数值分别对应机器人的号数,对应指令,以及执行该指令的次数。

等一切输入完后就可以执行(模拟)了。

输出有三种情况

一种是撞墙的

一种是撞机器人的

剩下的是每条指令都通过并没有发生意外(撞墙或撞机器人)的

对于前两种,我们得只输出一次就可以不管后面的了,因为题目要求只输出一次情况

但如果在输入时就开始模拟的话,中断了就会影响后面的输入,所以我弄了个结构体去存执行指令

剩下的,就看自己是否细心与耐心了

我语言比较菜,所以代码写得很长,很暴力,感觉有些地方还可以写的简练一点,但由于自己懒,想快水过去好睡觉了。

数据很小。

// POJ 2632
#include<iostream>
#include<cstdio>
using namespace std; int T;
int W, H, robot_n, t;
struct node{
int w, h;
char to;
}rob[102];
struct e{
int who, re;
char done;
}take[102];
//char pla[102][102]; void show(){
for(int i = 1; i <= robot_n; i++){
printf("i:%d w:%d h:%d\n", i, rob[i].w, rob[i].h);
}
} int main()
{
scanf("%d", &T);
while(T--){
bool last = true;
// take in
scanf("%d %d", &W, &H);
scanf("%d %d", &robot_n, &t);
for(int i = 1; i <= robot_n; i++) scanf("%d %d %c", &rob[i].w, &rob[i].h, &rob[i].to);
for(int i = 1; i <= t; i++) scanf("%d %c %d", &take[i].who, &take[i].done, &take[i].re); // done!
for(int i= 1; i <= t; i++){
int it = take[i].who;
char bi = take[i].done;
int num = take[i].re; // 转向
if(bi == 'L'){
num = num % 4;
while(num > 0){
if(rob[it].to == 'N') rob[it].to = 'W';
else if(rob[it].to == 'W') rob[it].to = 'S';
else if(rob[it].to == 'S') rob[it].to = 'E';
else if(rob[it].to == 'E') rob[it].to = 'N';
num--;
}
}
else if(bi == 'R'){
num = num % 4;
while(num > 0){
if(rob[it].to == 'N') rob[it].to = 'E';
else if(rob[it].to == 'E') rob[it].to = 'S';
else if(rob[it].to == 'S') rob[it].to = 'W';
else if(rob[it].to == 'W') rob[it].to = 'N';
num--;
}
}
// 前进
else if(bi == 'F'){
char go = rob[it].to;
// 北
if(go == 'N'){
while(num > 0){
rob[it].h++;
// wall
if(rob[it].h > H){
printf("Robot %d crashes into the wall\n", it);
last = false;
break;
}
// robot
bool can = true; // 跳出遍历
for(int i = 1; i <= robot_n; i++){
if(i == it) continue;
if(rob[it].h == rob[i].h && rob[it].w == rob[i].w){
printf("Robot %d crashes into robot %d\n", it, i);
can = false;
last = false;
break;
}
}
if(!can) break;
num--;
}
}
// 西
else if(go == 'W'){
while(num > 0){
rob[it].w--;
// wall
if(rob[it].w < 1){
printf("Robot %d crashes into the wall\n", it);
last = false;
break;
}
// robot
bool can = true;
for(int i = 1; i <= robot_n; i++){
if(i == it) continue;
if(rob[it].h == rob[i].h && rob[it].w == rob[i].w){
printf("Robot %d crashes into robot %d\n", it, i);
can = false;
last = false;
break;
}
}
if(!can) break;
num--;
}
}
// 南
else if(go == 'S'){
while(num > 0){
rob[it].h--;
// wall
if(rob[it].h < 1){
printf("Robot %d crashes into the wall\n", it);
last = false;
break;
}
// robot
bool can = true;
for(int i = 1; i <= robot_n; i++){
if(i == it) continue;
if(rob[it].h == rob[i].h && rob[it].w == rob[i].w){
printf("Robot %d crashes into robot %d\n", it, i);
can = false;
last = false;
break;
}
}
if(!can) break;
num--;
}
}
// 东
else if(go == 'E'){
while(num > 0){
rob[it].w++;
// wall
if(rob[it].w > W){
printf("Robot %d crashes into the wall\n", it);
last = false;
break;
}
// robot
bool can = true;
for(int i = 1; i <= robot_n; i++){
if(i == it) continue;
if(rob[it].h == rob[i].h && rob[it].w == rob[i].w){
printf("Robot %d crashes into robot %d\n", it, i);
can = false;
last = false;
break;
}
}
if(!can) break;
num--;
}
}
}
// 中断剩余操作防止过多输出
if(!last) break;
}
// 跳过 OK
if(!last) continue;
printf("OK\n");
}
return 0;
}

【POJ2632】Crashing Robots的更多相关文章

  1. 【题解】ARC101F Robots and Exits(DP转格路+树状数组优化DP)

    [题解]ARC101F Robots and Exits(DP转格路+树状数组优化DP) 先删去所有只能进入一个洞的机器人,这对答案没有贡献 考虑一个机器人只能进入两个洞,且真正的限制条件是操作的前缀 ...

  2. 【ZOJ1003】Crashing Balloon(DFS)

    Crashing Balloon Time Limit: 2 Seconds      Memory Limit: 65536 KB On every June 1st, the Children's ...

  3. 【seo】title / robots / description / canonical

    1.title title,就是浏览器上显示的那些内容,不仅用户能看到,也能被搜索引擎检索到(搜索引擎在抓取网页时,最先读取的就是网页标题,所以title是否正确设置极其重要. 1)title一般不超 ...

  4. 【HDOJ6229】Wandering Robots(马尔科夫链,set)

    题意:给定一个n*n的地图,上面有k个障碍点不能走,有一个机器人从(0,0)出发,每次等概率的不动或者往上下左右没有障碍的地方走动,问走无限步后停在图的右下部的概率 n<=1e4,k<=1 ...

  5. 【agc004e】Salvage Robots

    题目大意 一个n*m的矩阵,矩阵内有一个出口和若干个机器人,每一步操作可以使所有的机器人向任意方向移动一格,如果机器人出了边界就爆炸.求最多可以让多少个机器人走到出口. 解题思路 发现,移动所有机器人 ...

  6. 【题解】CF24D Broken Robots(收敛性)

    [题解]CF24D Broken Robots http://codeforces.com/problemset/problem/24/D 解1(不会写,口胡的) 获得一个比较显然的转移式子 \(dp ...

  7. poj2632 Crashing Robots

    Crashing Robots Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9859   Accepted: 4209 D ...

  8. POJ2632——Crashing Robots

    Crashing Robots DescriptionIn a modernized warehouse, robots are used to fetch the goods. Careful pl ...

  9. 【题解】CF#24 D-Broken Robots

    在某次考试的时候用过的办法,懒人必备……[笑哭] 一个非常显然的 dp,我们用 \(f[i][j]\) 表示第 \(i\) 行第 \(j\) 列的格子走到最后一排的期望步数转移即为 \(f[i][j] ...

随机推荐

  1. Java—十进制数对n进制数转换

    import java.math.BigInteger;import java.util.Scanner; /** * @auther Aohui * @create 2019-11-06-15:33 ...

  2. iptables限制访问

    iptables限制访问 常用命令 # 查看规则 iptables -L INPUT --line-numbers # 开放指定的端口 iptables -A INPUT -p tcp --dport ...

  3. 【转载】C#中Convert.ToDouble方法将字符串转换为double类型

    在C#编程过程中,可以使用Convert.ToDouble方法将字符串或者其他可转换为数字的对象变量转换为double类型,Convert.ToDouble方法有多个重载方法,最常使用的一个方法将字符 ...

  4. 【转载】C#中List集合中Last和LastOrDefault方法的差别

    在C#的List集合操作中,Last方法和LastOrDefault方法都会用来查找集合中最后一个符合条件的元素对象,但Last和LastOrDefault方法还是有差别的,建议使用LastOrDef ...

  5. node连接Mysql报错ER_NOT_SUPPORTED_AUTH_MODE

    报错信息 本人系统安装的是mysql-installer-community-8.0.18.0.msi这个版本,然后我本地使用node-mysql去连接数据库. test.js文件 var mysql ...

  6. INTERVAL 用法 mysql

    原文:https://blog.csdn.net/sqlquan/article/details/82699237 做个例子描述吧,也许更易于理解. 准备: 1.建表 create table INT ...

  7. CSS-宽度自适应和浏览器兼容笔记

    自适应 宽度自适应:网页元素根据窗口或子元素自动调整宽度 适用百分比进行设置,例如:100% 铺满:50% 占据一般宽度 块元素如果不设置宽度,默认为100% 自适应中可以设置最大或者最小宽度和高度 ...

  8. Flink入门 - API

    final StreamExecutionEnvironment streamExecutionEnvironment = StreamExecutionEnvironment.getExecutio ...

  9. 如何统一管理单个任务下所有API的同步情况?

    如何统一管理单个任务下所有API的同步情况 1. 一分钟完成单个API配置 单个API的配置包含:API名称.URL地址.请求方式.参数设置.自定义高级设置. 参数允许用户填写:Text.WebSer ...

  10. 【TBarCode SDK教程】TBarCode SDK 如何在 Microsoft Office 中工作?

    使用条形码软件组件 TBarCode SDK,你可以在 Microsoft Office 中快速且简便地创建各种条形码.都不需要任何编程的技巧,只需要点击几次鼠标就可以将TBarCode SDK集成到 ...