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

1. 문제 링크

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

2. 문제 조건

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. 컴퓨팅 사고

10진법을 124나라의 진법 형식대로 변환하는 문제입니다.

규칙

  • 규칙을 살펴보면 n % 3 == 0이 되는 시점에 값이 4가 되는것을 확인할 수 있습니다.
  • n % 3을 했을때의 나머지를 계속 앞의 값으로 넣어주면 해당되는 124나라의 숫자로 변경하는것을 확인할 수 있습니다.
  • res값이 = 일경우 res값을 4로 갱신해주고, 종료조건을 만들어주기위해서 n을 3으로 나눈값에서 -1을 빼주게 됩니다.
  • Stringbuilder를 사용한 이유는 String은 새로운 값을 할당될때마다 생성되기 때문에 효율이 떨어지게 되므로, Stringbuilder는 동일 객체내에서 문자열을 변경하는것이 가능합니다.
  • 마지막에 reverse() 함수를 사용하여 값을 출력시킨 이유는 역순으로 값이 들어가있는 상태이기 때문입니다.

4. 소스 코드

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21


public class 나라의숫자124 {
public static void main(String[] args) {
int n = 10;
StringBuilder answer = new StringBuilder();
while(n > 0){
int res = n % 3;

if(res == 0){
res = 4;
n = (n/3)-1;
}else {
n = (n/3);
}
answer.append(Integer.toString(res));
}
System.out.println(answer.reverse());
}
}