[프로그래머스] 124 나라의 숫자

chanyeong kim·2021년 11월 27일
0

프로그래머스

목록 보기
17/51

📩 -->문제설명

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

💡 solution(사용언어: python)

def solution(n):
    answer = ''
    while n > 0:
        n -= 1
        answer = '124'[n%3] + answer
        n //= 3
    return answer
    

👉 설명

  • 3진법을 이용해야 하는 문제였다.
  • 기본적으로 3진법은 0,1,2로 이루어져 있지만 여기서는 1,2,4가 필요 했기에 0 ->1, 1->2, 2->4로 생각해 주어 10진수를 124나라가 원하는대로 바꾸어 주었다!

결과

다른 풀이

def change124(n):
    if n<=3:
        return '124'[n-1]
    else:
        q, r = divmod(n-1, 3) 
        return change124(q) + '124'[r]

여기서는 divmod 함수를 써주었는데, divmod(a,b)는 (a//b, a%b)를 튜플 형태로 리턴해준다!!

🌈 느낀 점

3진법 은근 헷갈렸다..ㅎㅎ

출처: 프로그래머스

오류가 있으면 댓글 달아주세요🙂

0개의 댓글