[알고리즘과 자료구조] JAVA - 124나라의 숫자
문제 설명
124 나라가 있습니다. 124 나라에서는 10진법이 아닌 다음과 같은 자신들만의 규칙으로 수를 표현합니다.
124 나라에는 자연수만 존재합니다.
124 나라에는 모든 수를 표현할 때 1, 2, 4만 사용합니다.
예를 들어서 124 나라에서 사용하는 숫자는 다음과 같이 변환됩니다.
자연수 n이 매개변수로 주어질 때, n을 124 나라에서 사용하는 숫자로 바꾼 값을 return 하도록 solution 함수를 완성해 주세요.
제한사항
n은 500,000,000이하의 자연수 입니다.
문제풀이
class Solution {
public String solution(int n) {
// 1, 2, 4 배열 생성 ( 4가 0번째인 이유는 3으로 나누었을 때 나머지가 0일 경우 4의 값을 삽입하기 위함)
String[] num = {"4", "1", "2"};
String answer = "";
// tmp 변수 생성
int tmp = n;
while(tmp > 0){
// 배열의 index
int idx = tmp%3;
// 3진법으로 계산하기 위해 3으로 나눠준다.
tmp /= 3;
// 여기에서 함정 :: idx가 0인 경우 tmp의 값을 -1을 해주어야 함
if ( idx == 0 ){
tmp--;
}
// 나머지 값을 가장 뒤쪽부터 삽입하기 위함
answer = num[idx] + answer;
}
return answer;
}
}