🙌 출처 - 프로그래머스 🙌
문제 설명
124 나라가 있습니다. 124 나라에서는 10진법이 아닌 다음과 같은 자신들만의 규칙으로 수를 표현합니다.
예를 들어서 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 | result |
---|---|
1 | 1 |
2 | 2 |
3 | 4 |
4 | 11 |
'124'[n%3]을 이용했는데 0일때는 1, 1일때는 2, 2일때는 4를 출력하기 위해 순환할 때 마다 -1씩 해준것이 특징입니다.
def solution(n):
answer = ''
while n > 0:
n -= 1
answer = '124'[n%3] + answer
n //= 3
return answer
이 문제는 풀이에 비해 고민을 많이 했던 문제였다. 처음부터 직관적으로 이렇게 풀 생각을 한 것은 아니었고 3진법을 사용해야 되는 부분은 알겠는데 계속 해결이 안되던 찰나에 손으로 하나씩 써 내려갔는데 전체 숫자에서 -1씩 계속 해주게되면 나오게 되는 특징을 볼 수 있었다. 수와 관련된 문제들은 봐도봐도 쉽지만은 않은 것 같다😥