124 나라의 숫자 (Programmers 12899)

문파이더맨·2021년 5월 17일
0

Algorithm

목록 보기
19/58
post-thumbnail

🧑‍💻 124 나라의 숫자

  • 124 나라가 있습니다. 124 나라에서는 10진법이 아닌 다음과 같은 자신들만의 규칙으로 수를 표현합니다.

    • 124 나라에는 자연수만 존재합니다.
    • 124 나라에는 모든 수를 표현할 때 1, 2, 4만 사용합니다.
  • 예를 들어서 124 나라에서 사용하는 숫자는 다음과 같이 변환됩니다.

    10진법124나라10진법124나라
    11614
    22721
    34822
    411924
    5121041
  • 자연수 n이 매개변수로 주어질 때, n을 124 나라에서 사용하는 숫자로 바꾼 값을 return 하도록 solution 함수를 완성해 주세요.

  • 제한사항

    • n 은 500,000,000 이하의 자연수 입니다.
  • 입출력 예
nresult
11
22
34
411

🧑‍💻 해결방법

  • 1, 2, 4를 활용한 3진법 문제
  • 규칙만 찾으면 어느정도 금방 해결이 가능한 문제

🧑‍💻 코드

def solution(n) :
   answer = ''
.  # 3으로 나눈 나머지를 인덱스 값으로 활용
   country = [4, 1, 2]

   while n :
       answer = str(country[n % 3]) + answer
       # 3, 6, 9의 규칙을 보면 알 수 있다.
       if n % 3 == 0 :
           n = (n // 3) - 1
       else :
           n = n // 3

   return answer

🧑‍💻 총평

  • 어려운 문제는 아니나 규칙을 찾고 구현하는데에 약간 애썼던 문제.
  • 수학적인 것이 더 중요했다.
  • 최근에 어려운 알고리즘을 접하면서 문제푸는 것이 귀찮아졌었는데 다시 출발 해보려한다.
  • 할 게 매우 많지만 하나씩 다 해보기!
profile
Sever 개발할래요.

0개의 댓글