728x90
반응형
안녕하세요, 이번 포스팅은 3진법 뒤집기를 하려고 합니다.
문제 설명
자연수 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 해야 합니다.
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
public class TernaryFlip {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
Solution s = new Solution();
int rtn = s.solution(input.nextInt());
System.out.println("rtn : " + rtn);
input.close();
}
}
class Solution {
public int solution(int n) {
int answer = 0;
List<Integer> list = new ArrayList<Integer>();
while(n > 0) {
list.add(n%3);
n/=3;
}
int j = 0;
for (int i = list.size()-1; i >= 0 ; i--) answer += list.get(i) * Math.pow(3, j++);
return answer;
}
}
728x90
반응형
'코딩테스트 > 프로그래머스' 카테고리의 다른 글
[프로그래머스/javascript] 2018 KAKAO BLIND RECRUITMENT [1차] 다트 게임 (0) | 2020.12.09 |
---|---|
[프로그래머스/javascript] 모의고사 (0) | 2020.12.07 |
[프로그래머스/javascript] 2020 카카오 인턴쉽 키패드 누르기 (0) | 2020.12.05 |
[프로그래머스/java] 내적 (0) | 2020.12.04 |
[프로그래머스/java] 두개 뽑아서 더하기 (0) | 2020.12.04 |
댓글