백준 1463 - 1로 만들기 (파이썬)

Updated:

Answer

n = int(input())

dp = [0 for _ in range(n + 1)]

for i in range(2, n + 1):
    dp[i] = dp[i - 1] + 1  

    if i % 2 == 0 and dp[i] > dp[i // 2] + 1 :
        dp[i] = dp[i // 2] + 1
        
    if i % 3 == 0 and dp[i] > dp[i // 3] + 1 :
        dp[i] = dp[i // 3] + 1
        
print(dp[n])

Categories:

Updated: