Skip to content

BOJ 10162 전자레인지 풀이 #8

@allzeroyou

Description

@allzeroyou

문제 분석

첫 번째 단계(문제 요약 및 조건 파악)

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 documentation

Projects

No projects

Milestone

No milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions