简单模拟 蠢蠢机器人III

China☆狼群 提交于 2020-01-14 23:47:17

题目描述:
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;
}

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!