[프로그래머스] 3진법 뒤집기

LDH·2021년 3월 20일
0

🔑알고리즘

목록 보기
5/9
post-thumbnail

✨Link 3진법 뒤집기

🤔 문제

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

입출력 예

nonresult
예1457
예2125299

💡 접근

10진법을 3진법으로 변환시 n을 3으로 나누면서 나머지를 차례대로 list에 넣어주었다. 처음 mok은 n으로 두고, 3으로 나누는데 나눈 몫을 다시 mok에 넣어준다. 이 과정을 mok이 0이 될때까지 해준다. list에는 3진법으로 변환된 수가 역순으로 담겨있으므로 따로 처리해주지 않고 바로 10수로 변환해주었다.

💻 코드(1)_나의 풀이

class Solution {
    public int solution(int n) {
        int answer = 0;
        int mok=n;
        
        List<Integer> num=new ArrayList<>();
        //10진수->3진수
        while(mok!=0) {
        	num.add(mok%3);
        	mok=mok/3;
        }
        //3진수->10진수
        int cnt=num.size()-1;
        for(int i:num) {
        	answer+=(int) (i*Math.pow(3,cnt--));
        }
        
        return answer;
    }
}
  • 나머지를 리스트에 담을때, 역순으로 담기기때문에 따로 (3진법)반전은 해주지 않았다!

💻 코드(2)_다른 사람의 풀이

class Solution {
    public int solution(int n) {
        String a = "";

        while(n > 0){
            a = (n % 3) + a;//a+(n%3)
            n /= 3;
        }
        a = new StringBuilder(a).reverse().toString();

        return Integer.parseInt(a,3);
    }
}
  • 10->3진법으로 변환할때, a+(n%3)이렇게 해주면 reverse를 해주지 않아도 된다.
  • 마지막 return문에 Integer.parseInt(a,3);처럼 파라미터가 2개들어가는것은 처음 봐서 찾아보았다.
    🔎 public static int parseInt(String s): 문자열(s)을 인자값으로 받으면 해당값을 10진수의 Integer형으로 변환시켜주는 것이다.
    🔎 public static int parseInt(String s,int radix): 문자열(s)을 인자값으로 받으면 해당값을 진수(radix)의 Integer형으로 변환시켜주는 것이다.
profile
💻💻💻

0개의 댓글