본문 바로가기
알고리즘(프로그래머스)

프로그래머스 124 나라의 숫자

by coie 2021. 4. 4.

문제 설명

124 나라가 있습니다. 124 나라에서는 10진법이 아닌 다음과 같은 자신들만의 규칙으로 수를 표현합니다.

        124 나라에는 자연수만 존재합니다.

124 나라에는 모든 수를 표현할 때 1, 2, 4만 사용합니다.

 

예를 들어서 124 나라에서 사용하는 숫자는 다음과 같이 변환됩니다.

10진법 124 나라 10진법 124 나라

1 1 6 14
2 2 7 21
3 4 8 22
4 11 9 24
5 12 10 41

자연수 n이 매개변수로 주어질 때, n을 124 나라에서 사용하는 숫자로 바꾼 값을 return 하도록 solution 함수를 완성해 주세요.

 

제한사항

n은 500,000,000이하의 자연수입니다.

 

-------------

딱 보자마자 아 3 관련이구나 하고 

답이 String인 것을 보고 고민해서 ution 함수를 완성해 주세요.

 

 

 

제한사항

 

n은 500,000,000 이하의 자연수입니다.

 

 

 

-------------

 

딱 보자마자 아 3 관련이구나 하고 

 

답이 String인 것을 보고 고민해서

 

 public String solution(int n) {
        String answer = "";
        int temp;
        while(n>0){
            temp = n%3;
            n = n/3;
            if(temp==0){
                n -=1;
                temp=4;
            }
         answer=temp+answer;    
        }
        
        return answer;
    }

딱! 했는데

효율성에서 다 떨어졌다.

 

그래서... 답지를 찾아본 결과

public static String solution(int n) {
	String[] num = {"4", "1", "2"};
	String answer = "";

	while (n > 0) {
		answer = num[n % 3] + answer;
		n = (n - 1) / 3;
	}

	return answer;
}

미리 값을 배열에 담아 둔 후 하는 것...

그것 외에도 코드가 더 깔끔하다.

1,2,4라는 숫자만 사용한다는 것

그리고 그것을 while에서 해결을 합니다.

그리고 

n-1은 몫 값의 문제 해결