조건문-6단계_오븐시계
단계 | 제목 | 설명 | |
---|---|---|---|
2 | 조건문 | if 등의 조건문을 사용해 봅시다. | |
소단계 | 문제번호 | 제목 | |
6 | 2525 | 오븐시계 | |
범위가 더 넓은 시간 계산 문제 |
문제
KOI 전자에서는 건강에 좋고 맛있는 훈제오리구이 요리를 간편하게 만드는 인공지능 오븐을 개발하려고 한다. 인공지능 오븐을 사용하는 방법은 적당한 양의 오리 훈제 재료를 인공지능 오븐에 넣으면 된다. 그러면 인공지능 오븐은 오븐구이가 끝나는 시간을 분 단위로 자동적으로 계산한다.
또한, KOI 전자의 인공지능 오븐 앞면에는 사용자에게 훈제오리구이 요리가 끝나는 시각을 알려 주는 디지털 시계가 있다.
훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 분단위로 주어졌을 때, 오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오.
입력
첫째 줄에는 현재 시각이 나온다. 현재 시각은 시 A (0 ≤ A ≤ 23) 와 분 B (0 ≤ B ≤ 59)가 정수로 빈칸을 사이에 두고 순서대로 주어진다. 두 번째 줄에는 요리하는 데 필요한 시간 C (0 ≤ C ≤ 1,000)가 분 단위로 주어진다.
출력
첫째 줄에 종료되는 시각의 시와 분을 공백을 사이에 두고 출력한다. (단, 시는 0부터 23까지의 정수, 분은 0부터 59까지의 정수이다. 디지털 시계는 23시 59분에서 1분이 지나면 0시 0분이 된다.)
내 제출
hour_now , min_now = map(int, input().split())
min_cost = int(input())
min_final = min_now + min_cost
if min_final < 60:
print(hour_now,min_final)
elif min_final >= 60:
min_final = min_final - 60
hour_now = hour_now + 1
if hour_now < 24:
print(hour_now,min_final)
elif hour_now == 24:
hour_now = 0
print(hour_now,min_final)
결과
오답: 틀렸습니다.
수정 제출
hour_now , min_now = map(int, input().split())
min_cost = int(input())
min_final = min_now + min_cost
if min_final < 60:
print(hour_now,min_final)
elif min_final >= 60:
min_fix = min_final // 60
min_final = min_final - 60*min_fix
hour_now = hour_now + 1*min_fix
if hour_now < 24:
print(hour_now,min_final)
elif hour_now >= 24:
hour_now = hour_now - 24
print(hour_now,min_final)
결과
정답
오답 이유
이번문제의 오답 역시 문법적오류는 없습니다.
주요한 오답 파트로는 두가지가 있습니다.
1.min_final , hour_now 업데이트 알고리즘
elif min_final >= 60:
min_final = min_final - 60
hour_now = hour_now + 1
해당 부분에서 min_final , hour_now 를 업데이트 하는데 있어서 소요시간 min_cost 가 매우 큰 값일 경우 위와같은 알고리즘의 경우 오류가 발생합니다.
elif hour_now == 24:
hour_now = 0
print(hour_now,min_final)
또한 hour_now 가 24시를 넘었을 경우에도 위와같은 알고리즘을 적용시 매우큰 min_cost 적용시 일괄 0시로 업데이트 되는 오류가 발생합니다.
2.해결원리
이를
elif min_final >= 60:
min_fix = min_final // 60
min_final = min_final - 60*min_fix
hour_now = hour_now + 1*min_fix
if hour_now < 24:
print(hour_now,min_final)
elif hour_now >= 24:
hour_now = hour_now - 24
print(hour_now,min_final)
와 같이 min_final 의 60분으로 나눠준 몫을 사용하여 비례적으로 계산하고
이 결과에 따라 hour_now 역시 -24 를 해주어 비례적으로 결과를 도출하는 알고리즘을 구축하였습니다.