출처: 2018 E 기업 알고리즘 대회
어떠한 수 (N)이 1이 될 때까지 다음의 두 과정 중 하나를 반복적으로 선택하여 수행하려고 한다.
단, 두 번째 연산은 (N)이 (K)로 나누어떨어질 때만 선택할 수 있다.
예를 들어 (N = 17), (K = 4)라고 가정하자.
이때 1번의 과정을 한 번 수행하면 (N = 16)이 된다.
이후에 2번의 과정을 두 번 수행하면 (N = 1)이 된다.
결과적으로 이 경우 전체 과정을 실행한 횟수는 3이다.
이는 (N)을 1로 만드는 최소 횟수이다.
(N)과 (K)가 주어질 때 (N)이 1이 될 때까지 1번 혹은 2번의 과정을 수행해야 하는 최소 횟수를 구하는 프로그램을 작성하시오.
25 5
2
N, K = map(int, input().split())
count = 0
while N != 1:
if N % K != 0:
N = N - 1
count += 1
else:
N = N / K
count += 1
print(count)
N, K = map(int, input().split())
count = 0
while N >= K:
# N이 K로 나누어떨어지지 않으면 1을 빼는 대신 한 번에 차이만큼 감소
remain = N % K
count += remain
N -= remain
N //= K
count += 1
# 마지막으로 남은 N이 1이 될 때까지 처리
count += (N - 1)
print(count)