[프로그래머스/javascript] 29. 3진법 뒤집기

김두루 (FrontEnd Developer)·2022년 1월 19일

문제 설명

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


제한 조건

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

입출력 예

nresult
457
125229

입출력 예 설명

입출력 예 #1

  • 답을 도출하는 과정은 다음과 같습니다.
n(10진법)n(3진법)앞뒤 반전(3진법)10진법으로 표현
45120000217
  • 따라서 7을 return 해야 합니다.

입출력 예 #2

  • 답을 도출하는 과정은 다음과 같습니다.
n(10진법)n(3진법)앞뒤 반전(3진법)10진법으로 표현
1251112222111229
  • 따라서 229를 return 해야 합니다.

풀이

function solution(n) {
    var answer = 0;
    let s = n.toString(3);
    s = String(s).split("").reverse().join("");
    answer = parseInt(s, 3);
    return answer;
}

해설

N진수 변환 메서드를 이용하면 쉽게 해결 가능하다.

  • 10진수 ㅡ> N진수 : const s = num.tosrting(n) // num은 10진수 숫자, n은 진법
  • N진수 ㅡ> 10진수 : parseInt(s, 3) // , 뒤에는 몇진법을 사용했는지
profile
몰입하는 개발자

0개의 댓글