| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 1 | ||||||
| 2 | 3 | 4 | 5 | 6 | 7 | 8 |
| 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| 16 | 17 | 18 | 19 | 20 | 21 | 22 |
| 23 | 24 | 25 | 26 | 27 | 28 | 29 |
| 30 |
Tags
- 알고리즘
- BFS
- JavaScript
- 다이나믹 프로그래밍
- 브루트포스 알고리즘
- level2
- 백준
- DFS
- 정렬
- lv2
- 문자열
- 그래프 이론
- 프로그래머스스쿨
- 그래프이론
- 자료구조
- 그래프 탐색
- 웹 프론트엔드
- CSS
- 파이썬
- 자바스크립트
- 딕셔너리
- BASIC
- DP
- 너비 우선 탐색
- 프로그래머스
- 그리디 알고리즘
- web
- 스택
- 구현
- programmers
Archives
- Today
- Total
목록5585 (1)
DevLog:-)
문제 코드 import sys n = 1000-int(sys.stdin.readline()) M = [500, 100, 50, 10, 5, 1] count = 0 for money in M: if n == 0: break count += n // money #금액이 큰 거스름돈 먼저 잔돈 개수 계산 n %= money print(count) 문제설명 잔돈의 개수가 최소가 되도록 해야 하는 문제이다. 접근방법 그리디 알고리즘을 사용한다. 코드설계 -액수가 큰 지폐를 최대한 많이 사용해야하기 때문에 가장 큰 잔돈 500부터 내림차순으로 M에 저장한 후 for문을 돌린다. -for문을 돌면서 money로 거스름돈을 나눈 몫(해당 잔돈 개수)을 결괏값에 더한다. -그 후에 남은 거스름돈을 계산하고 남은 거스름돈..
알고리즘/백준
2023. 6. 7. 01:30