描述
我们定义一个无限大的二维网格上有一个小人,小人初始位置为 (0,0) 点,小人可以读取指令上下左右移动。
一个合法的指令由三至四个符号组成:
∙第一个符号为 "A/D/W/S" 中的一个,代表小人移动的方向;分别代表向左、向右、向上、向下移动;记某个时刻小人的坐标为 (x,y) ,向左移动一格即抵达 (x−1,y) 、向右移动一格即抵达 (x+1,y) 、向上移动一格即抵达 (x,y+1) 、向下移动一格即抵达 (x,y−1) 。
∙最后一个符号为 ";" ,代表指令的结束,该符号固定存在;
∙中间为一个 1-99 的数字,代表小人移动的距离。
如果你遇到了一个不合法的指令,则直接忽略;例如,指令 "A100;" 是不合法的,因为 100 超出了 1-99 的范围;"Y10;" 也是不合法的,因为 Y 不是 "A/D/W/S" 中的一个。
输出小人最终的坐标。
输入描述:
在一行上输入一个长度 1≦length(s)≦104 ,仅由可见字符构成的字符串 s ,代表输入的指令序列。
输出描述:
在一行上输出一个两个整数,代表小人最终位置的横纵坐标,使用逗号间隔。
const rl = require("readline").createInterface({ input: process.stdin });
var iter = rl[Symbol.asyncIterator]();
const readline = async () => (await iter.next()).value;
void (async function () {
// Write your code here
line = (await readline()).split(";");
const avaid = (s) => {
if (
!["A", "D", "W", "S"].includes(s[0]) ||
isNaN(s.slice(1)) ||
s.slice(1) > 99
)
return false;
return true;
};
let x = 0,
y = 0;
for (let i = 0; i < line.length; i++) {
if (avaid(line[i])) {
let num = parseInt(line[i].slice(1));
switch (line[i][0]) {
case "A":
x -= num;
break;
case "S":
y -= num;
break;
case "W":
y += num;
break;
case "D":
x += num;
break;
}
}
}
console.log(x + "," + y);
})();