某少年宮引進了一批機械人小車。可以接受預先輸入的指令,按指令行動。小車的基本動作很簡單,只有3種:左轉(記為l),右轉(記為r),向前走若干厘公尺(直接記數字)。
例如,我們可以對小車輸入如下的指令:
15l10r5lrr10r20
則,小車先直行15厘公尺,左轉,再走10厘公尺,再右轉,...
不難看出,對於此指令串,小車又回到了出發地。
你的任務是:編寫程式,由使用者輸入指令,程式輸出每條指令執行後小車位置與指令執行前小車位置的直線距離。
【輸入、輸出格式要求】
使用者先輸入乙個整數n(n<100),表示接下來將有n條指令。
接下來輸入n條指令。每條指令只由l、r和數字組成(數字是0~100之間的整數)
每條指令的長度不超過256個字元。
程式則輸出n行結果。
每條結果表示小車執行相應的指令前後位置的直線距離。要求四捨五入到小數後2位。
例如:使用者輸入:
5l100r50r10
3lll5rr4l12
ll100r
5l5l5l5
則程式輸出:
102.96
9.06
0.00
100.00
0.00
【注意】
請仔細除錯!您的程式只有能執行出正確結果的時候才有機會得分!
用模擬來完成的,用三個引數來記錄和決定到底要怎麼走,分別是當前的方向、左轉和右轉、前進的步數
挺簡單的並且注釋很全,直接貼碼...
#include #include #include #include using namespace std;
int horizontal=0,vertical=0;//分別記錄豎直和水平離開原點的距離
char judge(char now,char leforrig,int n)
else
case 's':
if(leforrig=='l')
else
case 'w':
if(leforrig=='l')
else
case 'e':
if(leforrig=='l')
else
} }int main()
while(i='0') //獲得分離出來的和 如果是連著轉向的話就跳過該步驟,直接記錄下和為0;
sum=(int)(sum*10+str[i++]-'0');
now=judge(now,tmpch,sum);
}printf("%.2f\n",sqrt(horizontal*horizontal+vertical*vertical));
}return 0;
}
藍橋杯 機械人行走
某少年宮引進了一批機械人小車。可以接受預先輸入的指令,按指令行動。小車的基本動作很簡單,只有3種 左轉 記為l 右轉 記為r 向前走若干厘公尺 直接記數字 例如,我們可以對小車輸入如下的指令 15l10r5lrr10r20 則,小車先直行15厘公尺,左轉,再走10厘公尺,再右轉,不難看出,對於此指令...
藍橋杯 機械人行走 模擬 類
某少年宮引進了一批機械人小車。可以接受預先輸入的指令,按指令行動。小車的基本動作很簡單,只有3種 左轉 記為l 右轉 記為r 向前走若干厘公尺 直接記數字 例如,我們可以對小車輸入如下的指令 15l10r5lrr10r20 則,小車先直行15厘公尺,左轉,再走10厘公尺,再右轉,不難看出,對於此指令...
機械人行走
某少年宮引進了一批機械人小車。可以接受預先輸入的指令,按指令行動。小車的基本動作很簡單,只有3種 左轉 記為l 右轉 記為r 向前走若干厘公尺 直接記數字 例如,我們可以對小車輸入如下的指令 15l10r5lrr10r20 則,小車先直行15厘公尺,左轉,再走10厘公尺,再右轉,不難看出,對於此指令...