본문 바로가기
Algorithm

[프로그래머스] 124 나라의 숫자 | JavaScript

by Vintz 2021. 6. 19.
반응형

124 나라의 숫자

문제 설명

124 나라가 있습니다. 124 나라에서는 10진법이 아닌 다음과 같은 자신들만의 규칙으로 수를 표현합니다.

  1. 124 나라에는 자연수만 존재합니다.
  2. 124 나라에는 모든 수를 표현할 때 1, 2, 4만 사용합니다.

예를 들어서 124 나라에서 사용하는 숫자는 다음과 같이 변환됩니다.

10진법 124 나라 10진법 124 나라
1 1 6 14
2 2 7 21
3 4 8 22
4 11 9 24
5 12 10 41

자연수 n이 매개변수로 주어질 때, n을 124 나라에서 사용하는 숫자로 바꾼 값을 return 하도록 solution 함수를 완성해 주세요.

제한사항

  • n은 500,000,000이하의 자연수입니다.

입출력 예

n result
1 1
2 2
3 4
4 11

코드

function solution(n) {
    let answer = '';
    const numArr = [4, 1, 2];
    
    while(n) {
        answer = numArr[n%3] + answer;
        // 0 == false
        n = n%3 === 0 ? n/3 -1 : Math.floor(n/3); 
    }
     
    return answer;
}

10진법 숫자 매개변수 n을 1, 2, 4로 이루어진 3개의 숫자만으로 표현하는 알고리즘을 구현해야 한다. 문제 설명의 변환표를 보면 3으로 나누어 나머지 숫자가 1인 경우엔 1, 2인 경우엔 2, 0인 경우엔 4로 변환되는 패턴을 볼 수 있다.

  1. 나머지 값으로 변환할 배열 numArr를 생성한다. (0번째 index 4, 1번째 index 1, 2번째 index 2)
  2. 매개변수 n이 0(false)이 될 때까지 반복문을 실행하는 while을 사용한다.
  3. answer에 변환한 값을 할당한다.
  4. 나머지 값이 0일 경우 몫에서 1을 뺀 숫자를 n에 할당한다.
  5. 아니라면 몫을 n에 할당한다.
반응형