Greedy_동전(11047)

Eugenius1st·2022년 9월 15일
0

Algorithm_Baekjoon

목록 보기
130/158
post-thumbnail

문제

준규가 가지고 있는 동전은 총 N종류이고, 각각의 동전을 매우 많이 가지고 있다.

동전을 적절히 사용해서 그 가치의 합을 K로 만들려고 한다. 이때 필요한 동전 개수의 최솟값을 구하는 프로그램을 작성하시오.

풀이

  • for문을 거꾸로 돌며 가장 높은 단위의 동전부터 계산

코드

#11047번 동전
import sys
#sys.stdin=open("input.txt", "rt")
N,K = map(int,input().split())
coins = []
answer = 0

for x in range(N):
    tmp = int(input())
    coins.append(tmp)


for i in range(N-1,-1,-1):
    answer += K//coins[i]
    K %= coins[i]

print(answer)

배운것

import sys
def input():
    return sys.stdin.readline().rstrip()

N, K = map(int,input().split())
arr = [int(input()) for _ in range(N)]
cnt = 0
# 이는 가장 큰 수부터 나누어 남은 몫을 더하면 된다 !!
# 나누는 수가 나누어 지는 수보다 크다면 몫은 0이겠지.
# 그럼 for문만 돌려서 확인 가능하다
for i in reversed(arr):
    cnt += K // i
    K = K % i
    if K == 0:
        break
print(cnt)
  • return sys.stdin.readline().rstrip() 으로 빨리 읽기
  • 배열 안에 for문으로 한줄로 읽기
  • for i in reverse 로 for문 거꾸로 읽기
  • k 가 0이라면 더 계산할 필요 없이 break로 시간단축하기

그리고 내 기억력은 금붕어

profile
최강 프론트엔드 개발자가 되고싶은 안유진 입니다

0개의 댓글