[프로그래머스][LV.2] 124 나라의 숫자 | python3
2025. 2. 4. 20:10ㆍ프로그래머스/LV.2
문제 링크: 124 나라의 숫자
문제 설명
문제 설명
124 나라가 있습니다. 124 나라에서는 10진법이 아닌 다음과 같은 자신들만의 규칙으로 수를 표현합니다.
124 나라에는 자연수만 존재합니다.124 나라에는 모든 수를 표현할 때 1, 2, 4만 사용합니다.
예를 들어서 124 나라에서 사용하는 숫자는 다음과 같이 변환됩니다.
자연수 n이 매개변수로 주어질 때, n을 124 나라에서 사용하는 숫자로 바꾼 값을 return 하도록 solution 함수를 완성해 주세요
제한사항
- n은 50,000,000이하의 자연수 입니다.
문제 풀이
분명 전에 비슷한 문제를 풀었었는데 (LV.1이나 LV.0에서) 기억이 안난다....
결국 약간 찾아봄ㅠㅜ
3진법을 활용한 풀이. 3으로 완전이 나누어 떨어지면 0이 아니라 4를 쓴다.
6같은 경우 3진법이면 20이 되지만 124나라의 경우 14가 됨.
앞의 자리가 -1이 되기 때문에 3으로 나누어 떨어진 몫에서 1을 빼고 다음 계산을 해야한다.
내코드
def solution(n):
answer = ''
while n:
tmp=n%3
if tmp==0:
tmp=4
n-=1
answer=str(tmp)+answer
n//=3
return answer
더보기
다른사람풀이
def solution(n):
result = ""
# 124 나라의 숫자 체계는 3의 배수마다 자릿수가 바뀌게 되니
# 편리하게 n에 1을 빼주어 3진법으로 구한다.(0을 활용하기 위함)
while (n > 0):
n -= 1
result = "124"[n%3] + result
n //= 3
return result
'프로그래머스 > LV.2' 카테고리의 다른 글
[프로그래머스][LV.2] 땅따먹기 | python3 (0) | 2025.02.06 |
---|---|
[프로그래머스][LV.2] 3 x n 타일링 | python3 (0) | 2025.02.06 |
[프로그래머스][LV.2] 멀리 뛰기 | python3 (0) | 2025.02.05 |
[프로그래머스][LV.2] 올바른 괄호 | python3 (0) | 2025.02.05 |
[프로그래머스][LV.2] 2 x n 타일링 | python3 (0) | 2025.02.04 |