[프로그래머스 | JS] Lv0. 수 조작하기 1

HICHULOG·2023년 7월 7일
0

프로그래머스

목록 보기
5/38
post-thumbnail

수 조작하기 1

📝 문제

정수 n과 문자열 control이 주어집니다. control은 "w", "a", "s", "d"의 4개의 문자로 이루어져 있으며, control의 앞에서부터 순서대로 문자에 따라 n의 값을 바꿉니다.
"w" : n이 1 커집니다.
"s" : n이 1 작아집니다.
"d" : n이 10 커집니다.
"a" : n이 10 작아집니다.
위 규칙에 따라 n을 바꿨을 때 가장 마지막에 나오는 n의 값을 return 하는 solution 함수를 완성해 주세요.

⛔️ 제한 사항

  • -100,000 ≤ n ≤ 100,000
  • 1 ≤ control의 길이 ≤ 100,000
    control은 알파벳 소문자 "w", "a", "s", "d"로 이루어진 문자열입니다.

💡 풀이

function solution(n, control) {
    let arr = control.split('')
    let result=n;
    for(let el of arr){
        switch(el){
            case "w": result+=1; break;
            case "a": result+=-10; break;
            case "s": result+=-1; break;
            case "d": result+=10; break;
        }
    }
    return result;
}

=> for of구문은 String일때도 적용가능하므로 굳이 배열로 만들어 줄 필요가 없었다.

function solution(n, control) {
    for(let i = 0 ; i < control.length ; i++){
        switch(control[i]) {
            case "w" : n++;break;
            case "s" : n--;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);
}

=> operations라는 객체를 만들어 w,s,d,a를 키로 설정. reduce()를 사용해 operations객체에 op에 해당하는 키를 불러주고 해당 키의 값의 인수로 prev를 줬다. 초기 시작값은 n으로 했다.

🚀 TIL

profile
🚀 Front-end Dev

0개의 댓글