[프로그래머스-기초] 수 조작하기 1

JiEun·2023년 6월 6일
0

코테/코플릿

목록 보기
22/56

수 조작하기 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"로 이루어진 문자열입니다.

입출력 예

ncontrolresult
0"wsdawsdassw"-1

입출력 예 설명

입출력 예 #1
수 n은 control에 따라 다음과 같은 순서로 변하게 됩니다.
0 → 1 → 0 → 10 → 0 → 1 → 0 → 10 → 0 → -1 → -2 → -1
따라서 -1을 return 합니다.

💻 내가 작성한 코드

function solution(n, control) {
    for(let i in control){
        if(control[i] === "w") ++n 
        if(control[i] === "s") --n
        if(control[i] === "d") n += 10
        if(control[i] === "a") n -= 10
    }
    return n
}

문자열은 유사 배열인 점을 이용해 for문으로 작성해 풀었다.

💻 다른 사람이 작성한 코드

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);
}

reduce로 생각 해 봤지만 생각 보다 잘 안되서 for문으로 작업했다.
이런 방법으로 작성하면 되는구나..

spread syntax 문법을 이용해 control를 배열로 만들고
reduce를 사용해 operations의 객체에서 operations[op]를 충족하는
값을 찾고 prev(이전 결과 값)에 연산을 해주는 거 같다.

function solution(n, control) {
    let answer = n;
    let map = {
        "w": 1,
        "s": -1,
        "d": 10,
        "a": -10
    };
    for(let i=0;i<control.length;i++)
        answer += map[control[i]];

    return answer;
}

w, s, d, a를 객체로 작성 후 넣어주고 풀어주니 가독성도 좋은 거 같다.


✏️ 마치며

조금만 복잡해 지면 메서드로 응용하는게
어려워 지는 거 같다.

객체 값을 만드는 방법 등 다양하니 이것저것 시도해 보자.

profile
💻 프론트엔드를 목표로 성장 중! (알아봤던 내용 등을 정리하기)

0개의 댓글