문제
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 함수를 완성해 주세요.
풀이
발견한 규칙은 표현할 수 있는 수의 갯수가 3개이므로 주어진 수 n을 계속 n으로 나누어가며 (0보다 작아질 때까지)
나머지(%)는 pattern 배열의 index로 사용하고, 몫은 n에 대입하여 나머지를 구하는 동작을 계속 반복해주면 된다는 것이다.
17을 예로 들자면
17 % 3 = 2 ===> 배열에서 2에 해당
몫인 5로 다시 수행 5 % 3 = 2 ===> 배열에서 2에 해당
몫인 1로 다시 수행 1 % 3 = 1 ===> 1에 해당
따라서 17을 124 나라의 수로 나타내면 122가 된다.
* 여기서 주의해야할 점은 3으로 떨어지는 수에 예외가 존재한다는 것이다.
18을 예로 들자면
18 % 3 = 0 ===> 배열에서 4에 해당
몫인 6로 다시 수행 6 % 3 = 0 ===> 배열에서 4에 해당
몫인 2로 다시 수행 2 % 3 = 2 ===> 2에 해당
244가 출력된다.
따라서 3으로 나누어 떨어지는 경우에는 (% 연산 결과가 0인 경우) 몫에서 1을 빼주어야 한다.
5 % 3 = 2 ===> 2
1 % 3 = 1 ===> 1
1을 빼준 후에는 124가 출력되게 됨
코드
package algorithm.Programmers.Lv2;
public class 일이사_나라의_숫자 {
public static void main(String[] args) {
int n = 24;
solution(n);
}
public static String solution(int n) {
String answer = "";
int pattern[] = {4, 1, 2};
int remainder;
while(n > 0) {
remainder = n % 3;
answer = pattern[remainder] + answer;
if(remainder == 0)
n--;
n = n / 3;
}
return answer;
}
}
'CS > Programmers' 카테고리의 다른 글
[Programmers.Lv2] 프린터 (0) | 2020.09.06 |
---|---|
[Programmers.Lv2] 기능개발 (1) | 2020.08.25 |
[Programmers.Lv1] 다트게임 (0) | 2020.08.23 |
[Programmers.Lv1] 비밀지도 (0) | 2020.08.20 |
[Programmers.Lv1] 크레인 인형 뽑기 게임 (0) | 2020.08.19 |