정수 n과 문자열 control이 주어집니다. control은 "w", "a", "s", "d"의 4개의 문자로 이루어져 있으며, control의 앞에서부터 순서대로 문자에 따라 n의 값을 바꿉니다.
위 규칙에 따라 n을 바꿨을 때 가장 마지막에 나오는 n의 값을 return 하는 solution 함수를 완성해 주세요.
n | control | result |
---|---|---|
0 | "wsdawsdassw" | -1 |
function solution(n, control) {
control.split("");
for (let i = 0; i < control.length; i++) {
switch (control[i]) {
case "w":
n += 1;
break;
case "s":
n -= 1;
break;
case "d":
n += 10;
break;
case "a":
n -= 10;
break;
}
}
return n;
}
const operations = {
w: (n) => n + 1,
s: (n) => n - 1,
d: (n) => n + 10,
a: (n) => n - 10,
};
function solution(n, control) {
return [...control].reduce((prev, op) => operations[op](prev), n);
}
function solution(n, control) {
return [...control].map(x => setValue(x)).reduce((a, b) => a+b, n);
}
function setValue(s){
return s==="w" ? 1 : s==="s" ? -1 : s==="d" ? 10 : -10;
}