版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/liujie2232692543/article/details/88980631
Description
最近俏智很兴奋,因为他收到了一个礼物,人称智能机器人佩奇,这个机器人很独特,当你给它发指令的时候,它就会按照你给出的指令去执行。看到这样的礼物,俏智乐坏了。于是他给你们出了这样的一道题: 假设在一个XOY坐标的平面上,机器人一开始位于原点,面向Y轴正方向。 机器人可以执行向左转,向右转,向后转,前进四个指令。 指令为1.LEFT:向左转2.RIGHT:向右转3.BACK:向后转4.FORWORD n:向前走n(1≤n≤100)个单位
那么如果俏智给出一个指令序列,你能帮忙求出机器人最终的位置吗?
Input
样例的第一行是一个整数T(T≤20),表示样例的个数。
每个样例的第一行是一个整数N(1≤N≤1,000),表示指令的条数。 以后的N行,每行一条指令。
Output
每个样例输出两个整数,为坐标(x,y),之间用空格隔开。
Sample Input 1
2 4 LEFT FORWORD 1 RIGHT FORWORD 1 2 BACK FORWORD 1
Sample Output 1
-1 1 0 -1
我的代码:
#include <bits/stdc++.h>
using namespace std;
int main()
{
int T;
cin >> T;
while(T--)
{
int n;
char a[1005];
int b=0;
int z=0;
int x = 0,y = 0;
cin >> n;
int chao = 0;
int f = 0;
for(int i=0;i<n;i++)
{
scanf("%s",a);
int len = strlen(a);
if(a[0] == 'R')
{
f = f+1;
}
else if(a[0] == 'L')
{
f = f-1;
}
else if(a[0] == 'B')
{
f = f+2;
}
else
{
scanf("%d",&b);
z = (4 + f )%4;
if(z == 0)
{
y = y+b;
}
else if(z == 1)
{
x = x+b;
}
else if(z == 2)
{
y = y - b;
}
else if(z == 3)
{
x = x-b;
}
chao = z;
}
// printf("%d %d\n",x,y);
}
printf("%d %d\n",x,y);
}
return 0;
}