코딩 테스트/프로그래머스 - 자바스크립트

프로그래머스 LV.0 수 조작하기 1

ctrs 2023. 9. 17. 13:56

프로그래머스 LV.0 수 조작하기 1

https://school.programmers.co.kr/learn/courses/30/lessons/181926

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

1. 문제 명

수 조작하기 1


2. 문제 설명

정수 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 함수를 완성해 주세요.


3. 제한 사항

- -100,000 ≤ n ≤ 100,000

- 1 ≤ control의 길이 ≤ 100,000

- control은 알파벳 소문자 "w", "a", "s", "d"로 이루어진 문자열입니다.


4. 예시

n control result
0 "wsdawsdassw" -1


5. 기본 제공 코드

function solution(n, control) {
    var answer = 0;
    return answer;
}


6. 제출한 내 답

const solution = (n, control) => {
  [...control].forEach((element) => {
    element === "w"
      ? (n += 1)
      : element === "s"
      ? (n -= 1)
      : element === "d"
      ? (n += 10)
      : (n -= 10);
  });
  return n;
};

 

6-2. VSC에 작성한 내용

const solution = (n, control) => {
  [...control].forEach((element) => {
    element === "w"
      ? (n += 1)
      : element === "s"
      ? (n -= 1)
      : element === "d"
      ? (n += 10)
      : (n -= 10);
  });
  return n;
};

// 테스트
console.log(solution(0, "wsdawsdassw"));


7. 특이사항

없음


8. 다른 사람이 작성한 답

8-1. redue

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

 

8-2. for switch 중첩반복문

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