자료구조 및 알고리즘/JavaScript Practice

JS Practice) 프로그래머스 Lv.1 : 3진법 뒤집기

Ryomi 2023. 6. 26. 08:02
728x90
반응형

 

3진법 뒤집기

문제설명 :

자연수 n이 매개변수로 주어집니다. n을 3진법 상에서 앞뒤로 뒤집은 후, 이를 다시 10진법으로 표현한 수를 return 하도록 solution 함수를 완성해주세요.

 

제한 사항

  • n은 1 이상 100,000,000 이하인 자연수입니다.

 

입출력 예

n result
45 7
125 229

 

접근

toString()에 radix를 넣어 3진법으로 해당 숫자를 읽어낸 후 뒤집었다. 이후 parseInt()를 이용해 해당 문자를 3진법으로 읽어 10진법으로 나타냈다.

function solution(n) {
    let str = n.toString(3).split('').reverse().join('')
    return parseInt(str, 3)
}

 

solution

function solution(n) {
    const answer = [];
    while(n !== 0) {
        answer.unshift(n % 3);
        n = Math.floor(n/3);
    }
    return answer.reduce((a, c, i) => a + (c * Math.pow(3, i)),0);   
}

 

728x90
반응형