题目描述:
PIPI升级了蠢蠢机器人,现在机器人站在直角坐标系的原点,面向y轴正方向,给定若干指令,求机器人最终位置。
指令格式:
“TURN”:右转90度。
“GO” NUM:直走NUM的距离。
输入:
输入包含多组测试数据,每组数据第一行为m,表示有m个操作,1<= m <= 100。
接下来m行,每行一个指令。
输出:
每组数据对应一行输出机器人最终所在的坐标,以空格隔开,保留3位小数。
样例输入:
3
TURN
GO 1
TURN
样例输出:
1.000 0.000
方向数组
#include<bits/stdc++.h>
using namespace std;
const int N=105;
int dir[4][2]={{0,1},{1,0},{0,-1},{-1,0}};
char s[N];
int main()
{
int n,m;
while(~scanf("%d",&n))
{
double a,x=0,y=0;
int t=0;
for(int i=1;i<=n;i++)
{
scanf("%s",s);
if(s[0]=='T')
t=(t+1)%4;
else
{
scanf("%lf",&a);
x+=dir[t][0]*a;
y+=dir[t][1]*a;
}
}
printf("%.3lf %.3lf\n",x,y);
}
return 0;
}