저장을 습관화

프로그래머스 LV.0 수 조작하기 2 본문

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

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

ctrs 2023. 9. 21. 17:09

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

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

 

프로그래머스

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

programmers.co.kr

 

1. 문제 명

수 조작하기 2


2. 문제 설명

정수 배열 numLog가 주어집니다. 처음에 numLog[0]에서 부터 시작해 "w", "a", "s", "d"로 이루어진 문자열을 입력으로 받아 순서대로 다음과 같은 조작을 했다고 합시다.

 

- "w" : 수에 1을 더한다.

- "s" : 수에 1을 뺀다.

- "d" : 수에 10을 더한다.

- "a" : 수에 10을 뺀다.

 

그리고 매번 조작을 할 때마다 결괏값을 기록한 정수 배열이 numLog입니다. 즉, numLog[i]는 numLog[0]로부터 총 i번의 조작을 가한 결과가 저장되어 있습니다.

 

주어진 정수 배열 numLog에 대해 조작을 위해 입력받은 문자열을 return 하는 solution 함수를 완성해 주세요.


3. 제한 사항

- 2 ≤ numLog의 길이 ≤ 100,000

- -100,000 ≤ numLog[0] ≤ 100,000

- 1 ≤ i ≤ numLog의 길이인 모든 i에 대해 |numLog[i] - numLog[i - 1]|의 값은 1 또는 10입니다.


4. 예시

numLog result
[0, 1, 0, 10, 0, 1, 0, 10, 0, -1, -2, -1] "wsdawsdassw"


5. 기본 제공 코드

function solution(numLog) {
    var answer = '';
    return answer;
}


6. 제출한 내 답

const solution = (numLog) => {
  cal = {
    "+1": "w",
    "-1": "s",
    "+10": "d",
    "-10": "a",
  };

  return numLog
    .reduce((a, b, i) => {
      return b < numLog[i + 1]
        ? a + cal[`+${numLog[i + 1] - b}`]
        : a + cal[`-${b - numLog[i + 1]}`];
    }, "")
    .replace(undefined, "");
};

 

6-2. VSC에 작성한 내용

const solution = (numLog) => {
  cal = {
    "+1": "w",
    "-1": "s",
    "+10": "d",
    "-10": "a",
  };

  // let a = [];
  // for (i = 1; i < numLog.length; i++) {
  //   // numLog[i-1]과 numLog[i]를 비교해서 차이를 기록하고 싶어
  //   // 계산식은 더하기 아니면 빼기 밖에 없어 현상 유지는 없어
  //   if (numLog[i - 1] < numLog[i]) {
  //     a.push(`+${numLog[i] - numLog[i - 1]}`);
  //   } else {
  //     a.push(`-${numLog[i - 1] - numLog[i]}`);
  //   }
  // }

  return numLog
    .reduce((a, b, i) => {
      return b < numLog[i + 1]
        ? a + cal[`+${numLog[i + 1] - b}`]
        : a + cal[`-${b - numLog[i + 1]}`];
    }, "")
    .replace(undefined, "");

  // return a.reduce((a, b) => {
  //   return a + cal[b];
  // }, "");
};

// 테스트
console.log(solution([0, 1, 0, 10, 0, 1, 0, 10, 0, -1, -2, -1]));
//                     +1 -1 +10 -10 +10 -10 +10 -10 -1 -2 +1


7. 특이사항

최근 풀었던 것 중에 가장 헷갈렸던것 같다

for문으로 한번 풀었으니 배열 메소드도 써보자 했는데 너무 오래 걸렸다


8. 다른 사람이 작성한 답

8-1. map

function solution(numLog) {
    const convert = {
        '1': 'w', '-1': 's', '10': 'd', '-10': 'a'
    };

    return numLog.slice(1).map((v, i) => {
        return convert[v - numLog[i]]
    }).join('')
}

slice로 맨 앞에 있는 요소를 지웠는데

numLog[0]이 0이 아니었으면 어떡하려고..?

 

 8-2. switch case

function solution(numLog) {
  //w +1,a-10,s-1,d+10

  let array = [...numLog]
  let answer = [];
  for(let i=0;i<array.length;i++){
    switch(array[i+1]-array[i]){
      case 1:
        answer.push('w')
        break;
      case -1:
        answer.push('s')
        break
      case 10:
        answer.push('d')
        break;
      case -10:
        answer.push('a')
        break;
    }
}
return answer.join('');
}

 

8-3. switch case

function solution(numLog) {
    let answer ="";
    for(let i = 0 ; i < numLog.length-1 ; i++ ){
        const val = numLog[i+1] - numLog[i];
        switch(val){
            case 1: answer+="w";break;
                case -10: answer+="a";break;
                case -1: answer+="s";break;
                case +10: answer+="d";break;
        }

    }
    return answer;
}