题目链接:机器人
题目思路:不想一个方向一个方向的判断,就去看了大佬的解析,有一个想法非常好。
指路->大佬的思路
大致就是:把他想象成【顺时针】向前向后转,向前为0(不用转),向右转为1(因为需要转一次),向后转为2(两个向右转相当于向后转),向左转为3(三个右转为左转)。
#include <bits/stdc++.h>
using namespace std;
int main()
{
int x, y, n;
x = y = 0;
int h = 1; //当前朝向,题目初始朝向x轴正方向。
int a[130], b[104]; //a存转向(需要转几次到达所需的方向),b存距离
char c[20];
scanf("%d", &n);
for(int i = 0; i < n; i++)
{
scanf("%s%d", c, &b[i]);
if(strcmp(c, "back")==0)
{
a[i] = 2;
}
else if(strcmp(c, "forward")==0)
{
a[i] = 0;
}
else if(strcmp(c, "left")==0)
{
a[i] = 3;
}
else if(strcmp(c, "right")==0)
{
a[i] = 1;
}
}
for(int i = 0; i < n; i++)
{
h = (h + a[i]) % 4; //当前方向+转的次数=目的方向
if(h==0)y += b[i];
if(h==1)x += b[i];
if(h==2)y -= b[i];
if(h==3)x -= b[i];
}
printf("%d %d\n", x, y);
return 0;
}