/* 3진법 뒤집기
* 자연수 n이 매개변수로 주어집니다. n을 3진법 상에서 앞뒤로 뒤집은 후,
* 이를 다시 10진법으로 표현한 수를 return 하도록 solution 함수를 완성해주세요.
*
* n은 1 이상 100,000,000 이하인 자연수입니다.
*
* n result
* 45 7 3진법 : 1200 / 반전 : 0021 / 10진법 : 7
* 125 229 3진법 : 11122 / 반전 : 22111 / 10진법 : 229
*/
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 | public class Programmer_1_39 { static int a1 = 1; static int a2 = 125; public String get3(int n){ String rst = ""; if(n < 3) return Integer.toString(n); while(1==1){ rst += Integer.toString(n % 3); n = n / 3; if(n < 3){ rst += Integer.toString(n); break; } } return rst; } public int solution(int n) { int answer = 0; System.out.println(get3(n) + " / " + get3(n).length()); String three = get3(n); int idx = 3; for(int i = three.length(); i > 0; i--){ if(i == three.length()) answer += Integer.parseInt(three.substring(i-1, i)); else{ answer += Integer.parseInt(three.substring(i-1, i)) * idx; idx = idx * 3; } } return answer; } /* 다른사람 풀이 public int solution(int n) { String a = ""; while(n > 0){ a = (n % 3) + a; n /= 3; } a = new StringBuilder(a).reverse().toString(); return Integer.parseInt(a,3); } */ public static void main(String args[]){ Programmer_1_39 t = new Programmer_1_39(); System.out.println("---------------------------------------"); System.out.println("result = " + t.solution(a1)); System.out.println("---------------------------------------"); // System.out.println("result = " + t.solution(a2)); // System.out.println("---------------------------------------"); } } | cs |
'프로그래머스 > lv1' 카테고리의 다른 글
예산 (0) | 2022.12.20 |
---|---|
이상한 문자 만들기 (0) | 2022.12.20 |
같은 숫자는 싫어 (1) | 2022.12.20 |
최대공약수와 최소공배수 (0) | 2022.12.20 |
직사각형 별찍기 (0) | 2022.12.19 |