[Programmers] - 124 나라의 숫자

오동훈·2021년 5월 6일
0

Programmers

목록 보기
34/64
post-thumbnail

1. Problem 📃

🙌 출처 - 프로그래머스 🙌

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

  1. 124 나라에는 자연수만 존재합니다.
  2. 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

2. Logic 👨‍🏫

'124'[n%3]을 이용했는데 0일때는 1, 1일때는 2, 2일때는 4를 출력하기 위해 순환할 때 마다 -1씩 해준것이 특징입니다.

3. Code 💻

1. 내가 푼 코드

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

4. Feedback 📚

이 문제는 풀이에 비해 고민을 많이 했던 문제였다. 처음부터 직관적으로 이렇게 풀 생각을 한 것은 아니었고 3진법을 사용해야 되는 부분은 알겠는데 계속 해결이 안되던 찰나에 손으로 하나씩 써 내려갔는데 전체 숫자에서 -1씩 계속 해주게되면 나오게 되는 특징을 볼 수 있었다. 수와 관련된 문제들은 봐도봐도 쉽지만은 않은 것 같다😥

profile
삽질의 기록들🐥

0개의 댓글