알고리즘
프로그래머스 12899 - 124 나라의 숫자
ljw4104
2021. 9. 27. 13:39
https://programmers.co.kr/learn/courses/30/lessons/12899
코딩테스트 연습 - 124 나라의 숫자
programmers.co.kr
문제 설명
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개를 가지고 수를 표현 -> 3진법과 매우 유사하지만, 3의 배수일때만 뭔가 다르다.
왜냐하면 124 나라에는 0을 표현할 방법이 없기 때문이다. 그래서 3의 배수일 때는 1을 빼주고 4를 반환하면 된다.
나머지는 3진법을 바꾸는 방법 그대로...
def third(n):
lst = []
while n > 0:
if n % 3 == 0:
lst.append(str(4))
n -= 1
else:
lst.append(str(n % 3))
n = n // 3
lst.reverse()
return ''.join(lst)
def solution(n):
return third(n)