[programmers] 3진법 뒤집기 - Java
자연수 n을 3진법으로 변환 후 뒤집고, 다시 10진법으로 변환하는 문제를 풀이한다. 이를 위해 `Integer.toString(문자열, 변환할 진법)`으로 10진수를 다른 진법으로 변환하고, `Integer.parseInt(문자열, 문자열의 진법)`으로 다른 진법의 수를 10진수로 변환한다. 이 문제를 통해 10진수와 다른 진법간의 변환 방법을 익힐 수 있다.
Feb 22, 2024
문제 설명
자연수 n이 매개변수로 주어집니다. n을 3진법 상에서 앞뒤로 뒤집은 후, 이를 다시 10진법으로 표현한 수를 return 하도록 solution 함수를 완성해주세요.
제한사항
- n은 1 이상 100,000,000 이하인 자연수입니다.
입출력 예
n | result |
45 | 7 |
125 | 229 |
입출력 예 설명
입출력 예 #1
- 답을 도출하는 과정은 다음과 같습니다.
n (10진법) | n (3진법) | 앞뒤 반전(3진법) | 10진법으로 표현 |
45 | 1200 | 0021 | 7 |
- 따라서 7을 return 해야 합니다.
입출력 예 #2
- 답을 도출하는 과정은 다음과 같습니다.
n (10진법) | n (3진법) | 앞뒤 반전(3진법) | 10진법으로 표현 |
125 | 11122 | 22111 | 229 |
- 따라서 229를 return 해야 합니다.
solution.java
class Solution { public int solution(int n) { StringBuilder sb = new StringBuilder(Integer.toString(n,3)); String reversed = sb.reverse().toString(); return Integer.parseInt(reversed,3); } }
핵심 키워드
Integer.toString(문자열, 변환할 진법)
을 통해 10진수 문자열을 원하는 진수로 변환할 수 있다.
Integer.parseInt(문자열, 문자열의 진법)
을 통해 특정 진법의 문자열을 10진수로 변환할 수 있다.
결론!
해당 문제를 풀면서 Integer.toString()과 Integer.parseInt()를 이용해 10진수와 다른 진법간의 변환 방법을 익힐 수 있었다.
Share article