机械之心

版权声明:本文为博主原创文章,未经博主允许不得转载。 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;
}

猜你喜欢

转载自blog.csdn.net/liujie2232692543/article/details/88980631