본문 바로가기

Programming/Programmers

[프로그래머스/Python] 3진법 뒤집기(진법변환)

 

코딩테스트 연습 - 3진법 뒤집기

자연수 n이 매개변수로 주어집니다. n을 3진법 상에서 앞뒤로 뒤집은 후, 이를 다시 10진법으로 표현한 수를 return 하도록 solution 함수를 완성해주세요. 제한사항 n은 1 이상 100,000,000 이하인 자연수

programmers.co.kr

 

진법변환 연습하는 문제

 

def ten2three(n):
    s = ""
    while n > 0:
        mok , namo = divmod(n, 3)
        s += str(namo) # 뒤집어서 저장
        n = mok
    return s

def three2ten(n):
    out = 0
    for i, num in enumerate(n):
        out += int(num) * pow(3, len(n)-i-1)
    return out

def solution(n):
    answer = 0
    num = ten2three(n)
    answer = three2ten(num)
    return answer