문제 설명
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이하의 자연수 입니다.
입출력 예
nresult
1 | 1 |
2 | 2 |
3 | 4 |
4 | 11 |
나의 풀이
패턴을 코드로 옮겨보는 데서 뭔가 지독하게 꼬여서 잘 안 풀린 느낌이 있습니다. 3진법에서 1씩 빠진 느낌인 건 이해를 했는데, 이걸 단순하게 코드로 적기가 힘들어서 재귀와 분기까지 두면서 풀었는데, 제출하고 참고해보니 더 간단하게 해결하는 방법이 있었습니다.
초기 풀이
def dfs(n, nums):
if (n < 4):
return str(nums[n % 3 - 1])
if (n % 3 == 0):
n = n - 3
return dfs(n // 3, nums) + dfs(n % 3, nums)
def solution(n):
nums = [1, 2, 4]
return dfs(n, nums)
개선된 풀이
def solution(n):
nums = [1, 2, 4]
answer = ''
while (n > 0):
n -= 1
answer = str(nums[n % 3]) + answer
n = n // 3
return answer
이런식으로 반복문을 진입할 때마다 1씩 빼주면서 하면 패턴에 맞게 해결할 수 있습니다.
'알고리즘&자료구조' 카테고리의 다른 글
[프로그래머스] 멀쩡한 사각형 - Python (0) | 2021.01.02 |
---|---|
[프로그래머스] k번째 수 (0) | 2020.12.29 |
프로그래머스 - 더 맵게(Python/파이썬) (0) | 2020.09.13 |
[Java][트리] Leetcode - 116. Populating Next Right Pointers in Each Node (0) | 2020.07.05 |
정렬 알고리즘 (Do it! 자바편 정리) (0) | 2020.06.07 |