3진법 뒤집기
문제설명 :
자연수 n이 매개변수로 주어집니다. n을 3진법 상에서 앞뒤로 뒤집은 후, 이를 다시 10진법으로 표현한 수를 return 하도록 solution 함수를 완성해주세요.
제한 사항
입출력 예
n | result |
45 | 7 |
125 | 229 |
입출력 예 #1
n (10진법)n (3진법)앞뒤 반전(3진법)10진법으로 표현
n (10진법) | n (3진법) | 앞뒤 반전(3진법) | 10진법으로 표현 |
45 | 1200 | 0021 | 7 |
입출력 예 #2
n (10진법)n (3진법)앞뒤 반전(3진법)10진법으로 표현
n (10진법) | n (3진법) | 앞뒤 반전(3진법) | 10진법으로 표현 |
125 | 11122 | 22111 | 229 |
접근
: parseInt가 문자열을 특정 진법으로 읽은 후 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((acc,v,i) => acc + (v * Math.pow(3, i)),0);
}
JS Practice) 프로그래머스 Lv.1 : 3진법 뒤집기 (0) | 2023.06.26 |
---|---|
JS Practice) 프로그래머스 Lv.1 : 같은 숫자는 싫어 (0) | 2023.06.22 |
JS Practice) 프로그래머스 Lv.1 : 행렬의 덧셈 (0) | 2023.06.21 |
JS Practice) 프로그래머스 Lv.1 : 문자열 다루기 기본 (0) | 2023.06.20 |
JS Practice) 프로그래머스 Lv.1 : 부족한 금액 계산하기 (0) | 2023.06.19 |
댓글 영역