2022. 2. 2. 13:20ㆍ알고리즘/그리디
문제
놀이공원에서 여러 개의 놀이기구를 맡아 일하는 세혁이와 근영이는 서로 좋아하는 사이이다. 그들은 쉬는 시간을 이용하여 둘만의 시간을 가지기를 원한다. 그래서 매일 일과 시작 전에 놀이기구의 운영 일정을 보고, 그날 둘이 함께할 수 있는 가장 긴 휴식시간이 언제인지를 찾으려고 한다.
놀이공원에서 일하는 모든 사람들은 어떤 놀이기구가 작동을 시작하기 10분 전부터, 모든 놀이기구가 작동을 멈춘 후 10분 후까지는 쉴 수 없고, 그 나머지 일과 시간에만 쉴 수 있다.
하루 일과를 시작하는 시각은 오전 10시이고, 일과를 마치는 시각은 오후 10시이다. 예를 들어 세 개의 놀이기구가 작동하는 시간이 다음과 같다고 하면,
- 놀이기구 1: 오전 10시 30분 - 오후 1시
- 놀이기구 2: 오후 7시 00분 - 오후 9시 10분
- 놀이기구 3: 오후 12시 30분 - 오후 4시 50분
세혁이와 근영이는 놀이기구 1이 운행되기 전에 20분, 놀이기구 3의 운행이 끝나고 놀이기구 2의 운행시작 전 사이에 1시간 50분, 놀이기구 2의 운행이 끝난 후에 40분 동안 쉴 수 있다. 따라서 둘이 함께할 수 있는 가장 긴 시간은 1시간 50분이다.
놀이기구 운영 일정이 주어질 때, 그 날 세혁이와 근영이가 함께할 수 있는 가장 긴 시간을 구하는 프로그램을 작성하시오.
입력
첫째 줄에 놀이기구의 개수 N이 주어진다. 이어 N줄에 걸쳐 각 놀이기구의 운행시작 시각과 종료 시각이 빈 칸을 사이에 두고 주어진다. 시각은 시간단위 두 자리, 분 단위 두 자리로 구성되며 오후 1시는 13시, 오후 2시는 14시, ... , 오후 10시는 22시로 표현된다. N은 50이하의 자연수이다.
출력
첫째 줄에 세혁이와 근영이가 함께할 수 있는 가장 긴 시간을 분 단위로 출력한다. 만약 함께할 수 있는 시간이 없다면 첫째 줄에 0을 출력한다.
예제 입력 1
3 1030 1300 1900 2110 1230 1650
예제 출력 1
110
접근 방법
- 0. 주어진 숫자를 분단위로 바꾸어 저장한다.
- 1. 놀이기구 시작시간을 기준으로 값을 정렬한 뒤, 값을 하나씩 탐색하며 쉬는 시간을 계산하여 가장 긴 쉬는 시간을 출력한다.
코드
# https://www.acmicpc.net/problem/2594
# 접근 방법
# 0. 주어진 숫자를 분단위로 바꾸어 저장한다.
# 1. 놀이기구 시작시간을 기준으로 값을 정렬한 뒤, 값을 하나씩 탐색하며 쉬는 시간을 계산하여 가장 긴 쉬는 시간을 출력한다.
n = int(input())
arr = [list(map(lambda x: int(x[:2]) * 60 + int(x[2:]), input().split())) for _ in range(n)]
arr.sort(key=lambda x: x[0])
result = max(0, arr[0][0] - 610)
e = arr[0][1]
for x in arr:
if x[0] - 10 > e + 10:
result = max(x[0] - (e + 20), result)
e = max(x[1], e)
result = max(60*22 - (e + 10), result)
print(result)
'알고리즘 > 그리디' 카테고리의 다른 글
백준 온라인 저지, 그리디 / 1049번: 기타줄 (파이썬 / , 백준 실버문제) (0) | 2022.04.06 |
---|---|
백준 온라인 저지, 그리디 / 12931번: 두배더하기 (파이썬 / , 백준 골드문제) (0) | 2022.02.02 |
백준 온라인 저지, 그리디 / 11508번: 2+1세일 (파이썬 / , 백준 실버문제) (0) | 2022.02.02 |
백준 온라인 저지, 그리디 / 9237번: 이장님초대 (파이썬 / , 백준 실버문제) (0) | 2022.01.02 |
백준 온라인 저지, 그리디 / 20311번: 화학실험 (파이썬 / , 백준 골드문제) (0) | 2021.12.11 |