机器人站在笛卡尔坐标系的原点,面向y轴正方向,给定若干指令,求机器人最终位置。
多组测试数据,每组数据第一行为m,表示有m个操作,0 < m < 100。
接下来m行,每行一个指令。
指令格式:
“TURN”:右转90度。
“GO” NUM:直走NUM的距离。
每组数据对应一行输出机器人最终所在的坐标,空格隔开,保留3位小数。
数据保证最终结果可以用double精确表示。3 TURN GO 1 TURN
1.000 0.000
思路:模拟,先判断出是 TURN还是GO,为T的时候%4确定是X变化还是Y变化。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iomanip>
using namespace std;
int main()
{int T;while(cin>>T){int cnt=1;double x=0.0,y=0.0;while(T--){string s;cin>>s;if(s[0]=='T'){cnt++;}else{double num;cin>>num;if(cnt%4==1)y+=num;else if(cnt%4==2)x+=num;else if(cnt%4==3)y-=num;else x-=num;}}cout<<fixed<<setprecision(3)<<x<<" "<<y<<endl;}return 0;
}
本文发布于:2024-02-04 19:05:08,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170714334758623.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |