그리디 알고리즘 2


그리디 알고리즘 2(1이 될 때까지)

출처 : (이코테 2021 강의 몰아보기) 2. 그리디 & 구현
https://www.youtube.com/watch?v=2zjoKjt97vQ&list=PLRx0vPvlEmdAghTr5mXQxGpHjWqSz0dgC

문제

어떠한 수 N이 1이 될 때까지 다음의 두 과정 중 하나를 반복적으로 선택하여 수행하려고 합니다.
단, 두번째 연산은 N이 K로 나누어 떨어질 때만 선택할 수 있습니다

  1. N에서 1을 뻅니다.
  2. N을 K로 나눕니다.
    예를 들어 N이 17, K가 4라고 가정합시다.
    이때 1번의 과정을 한 번 수행하면 N은 16이 됩니다.
    이후에 2번의 과정을 두 번 수행하면 N은 1이 됩니다. 결과적으로 이 경우 전체 과정을 실행한 횟수는 3이 됩니다.
    이는 N을 1로 만드는 최소 횟수입니다.
    N과 K가 주어질 때 N이 1이 될 때까지 1번 혹은 2번의 과정을 수행해야 하는 최소 횟수를 구하는 프로그램을 작성하세요

코드

#1이 될때 까지(나)
N,K=map(int,input().split())
cnt=0
while((N%K)!=0):
    N-=1
    cnt+=1
while(N!=1):
    cnt+=1
    N/=K
print(cnt)
#1이 될때 까지(답)
N,K=map(int,input().split())
cnt=0
while True:
    # N이 K로 나누어 떨어지는 수가 될 때까지 빼기
    target=(N//K)*K
    cnt+=(N-target)
    N=target
    # N이 K보다 작을 때 (더 이상 나눌 수 없을 때) 반복문 탈출
    if N<K:
        break
    # K로 나누기
    cnt+=1
    N//=K
# 마지막으로 남은 수에 대하여 1씩 빼기
cnt+=(N-1)
print(cnt)





© 2021.07. by 전은성

Powered by 전은성