-
Notifications
You must be signed in to change notification settings - Fork 0
Open
Labels
documentationImprovements or additions to documentationImprovements or additions to documentation
Description
문제 분석
첫 번째 단계(문제 요약 및 조건 파악)
3개의 시간조절용 버튼 A B C가 달린 전자레인지.
각 버튼마다 일정한 시간이 지정되어 있음.
해당 버튼을 누를 때 마다 그 시간이 동작시간에 더해짐.
버튼 A, B, C에 지정된 시간: 5분, 1분, 10초
냉동 음식마다 전자레인지로 요리해야할 시간 T가 초단위로 표시됨.
A,B,C 버튼을 적절히 눌러 그 시간의 합이 정확히 T초가 되도록 해야함.
단 버튼 A,B,C를 누른 횟수의 합은 항상 최소이어야.→ 최소 버튼 조작.
만약 요리시간이 100초라고 하면(t=100), b를 1번, c는 4번 누르면 됨.
이때 c를 10번 눌러도 100초가 되지만 10번은 최소 횟수가 아니기 때문에 답이 될 수 없음.
이 경우에는 b 1번, c 4번으로 5번이 최소버튼 조작임.
t=234와 같이 3개의 버튼으로 시간을 정확히 맞출 수 없는 경우도 있음.
주어진 요리 시간 t초를 맞추기 위한 최소버튼 조작 방법을 구하는 프로그램 작성하라.
입력
- 요리시간 t가 정수로 주어짐(1 ≤ T ≤ 10,000)
출력
- t초를 위한 최소버튼 조작 a, b, c 횟수를 차례대로 출력. 각각의 횟수 사이에는 빈 칸을 두기.
- 해당 버튼을 누르지 않을 때는 숫자 0 출력.
- 3개의 버튼으로 t초를 맞출 수 없다면 음수 -1을 첫 줄에 출력.
두 번째 단계 (문제 핵심 파악)
거스름돈 문제의 일종이라고 생각이 들었다.
그래서, 버튼을 누르는 횟수(몫)를 구한다음, 해당 버튼을 key로, 이 횟수를 딕셔너리의 value로 넣는다.
그리고 t가 10보다 클때까지 반복한다.(10보다 작다면, 더 이상 나눌 수 없는 수이기 때문에)
코드 작성
t = int(input())
btn = [300, 60, 10]
cnt = {}
while t >= 10:
for b in btn:
click_cnt = t // b
cnt[b] = click_cnt
t -= (click_cnt * b)
if t == 0:
for k, v in cnt.items():
print(v, end=' ')
else:
print(-1)느낀점
문제가 길었지만 본질은 거스름돈 문제였다.
본질을 파악하자.
Metadata
Metadata
Assignees
Labels
documentationImprovements or additions to documentationImprovements or additions to documentation