일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- programmers
- 가상환경
- String Method
- NumPy
- type hint
- Algorithm
- 코딩테스트
- 노마드코딩
- Selenium
- Stack
- 알고리즘
- pandas
- 프로그래머스
- javascript
- 파이썬
- 정보처리기사 c언어
- 선그래프
- 알고리즘스터디
- Matplotlib
- 자료구조
- Join
- openCV
- aws jupyter notebook
- 알고리즘 스터디
- python
- 데이터시각화
- queue
- dataframe
- 백준
- MySQL
- Today
- Total
조금씩 꾸준히 완성을 향해
[Algorithm] 백준 2525 오븐 시계 with Python 본문
문제
KOI 전자에서는 건강에 좋고 맛있는 훈제오리구이 요리를 간편하게 만드는 인공지능 오븐을 개발하려고 한다. 인공지능 오븐을 사용하는 방법은 적당한 양의 오리 훈제 재료를 인공지능 오븐에 넣으면 된다. 그러면 인공지능 오븐은 오븐구이가 끝나는 시간을 분 단위로 자동적으로 계산한다.
또한, KOI 전자의 인공지능 오븐 앞면에는 사용자에게 훈제오리구이 요리가 끝나는 시각을 알려 주는 디지털 시계가 있다.
훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 분단위로 주어졌을 때, 오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오.
입력
첫째 줄에는 현재 시각이 나온다. 현재 시각은 시 A (0 ≤ A ≤ 23) 와 분 B (0 ≤ B ≤ 59)가 정수로 빈칸을 사이에 두고 순서대로 주어진다. 두 번째 줄에는 요리하는 데 필요한 시간 C (0 ≤ C ≤ 1,000)가 분 단위로 주어진다.
출력
첫째 줄에 종료되는 시각의 시와 분을 공백을 사이에 두고 출력한다. (단, 시는 0부터 23까지의 정수, 분은 0부터 59까지의 정수이다. 디지털 시계는 23시 59분에서 1분이 지나면 0시 0분이 된다.)
예제 입력 1
14 30
20
예제 출력 1
14 50
▶ 내가 짠 코드
1. if문 활용
h, m = map(int, input().split())
cook = int(input())
end_m = (m + cook) % 60
end_h = h
if m + cook >= 60:
end_h = h + ((m + cook) // 60)
if end_h > 23:
end_h = end_h - ((end_h // 24)*24)
print(end_h, end_m)
현재 시간에 요리 시간을 더하는 모든 조건을 확인하는 방식이다.
더한 시가 24를 넘어갈 수도 있고, 더한 분이 60이 넘어갈 수도 있기 때문에 빠짐없이 다 체크해 주어야 한다.
우선 분의 값은 60이 넘더라도 무조건 현재 분 + 요리 분을 60으로 나눈 나머지가 된다.
시간의 경우 60분 이상이면 초과 분을 시간에다 더해준다.
그리고 추가로 이 더해준 시간이 24시 이상이면 초과 일수를 계산해서 빼준다. (일수는 상관없이 시간만 구하면 되기 때문)
2. while문 활용
다른 분들의 코드를 슬적 보는데 while문을 사용한 게 보였다. 띠용! 하고 눈이 떠져서 나도 고민해 보았다.
h, m = map(int, input().split())
cook = int(input())
m += cook
while h >= 24 or m >= 60:
if m >= 60:
h += 1
m -= 60
else:
if h >= 24:
h -= 24
print(h, m)
분이 60분이 넘어가면 시간을 하나씩 더하고, 시간이 24시가 넘어가면 24를 빼주는 과정을 원하는 결과 형태가 나올 때까지 계속 반복하면 되는 것이기 때문에 while 문이 오히려 간단하고 깔끔했다.
while 문의 조건을 어떻게 걸어야 할지 한참을 머리 싸맸는데, 시간이 24이상이거나 분이 60 이상인 경우에는 계속 반복하는 것으로 넣어주니 결과가 잘 나왔다..
정답이 나온 세가지 코드 길이가 점점 줄어든 걸 볼 수 있다.
처음은 if 문을 정리없이 친 것, 두번째는 변수와 중복을 정리한 것, 세번째는 while 문을 사용한 것이다.
짧고 간결하면서도 알아보기 쉬운 코드를 짜기 위해 노력해자! 화이팅!
'DataStructure & Algorithm > 문제풀이' 카테고리의 다른 글
[Algorithm] 백준 1065 한수 with Python (0) | 2022.09.22 |
---|---|
[Algorithm] 백준 8958 OX퀴즈 with Python (0) | 2022.09.22 |
[Algorithm] 부분 수열의 합 (0) | 2022.09.13 |
[Algorithm] 기초 문제 / 카드 역배치 (0) | 2022.09.06 |
[Algorithm] 기초 문제 / 숫자만 추출 (0) | 2022.09.06 |