Задача к ЕГЭ по информатике на тему «Распределение объектов по местам (хранение багажа, парковки, кафе, гостиницы)» №1

Задание выполняется с использованием прилагаемых файлов.

В аэропорту расположены камеры хранения, состоящие из K  ячеек. Ячейки камер хранения пронумерованы, начиная с 1  . Пассажиры сдают багаж в эти ячейки. Багаж кладётся в свободную ячейку с минимальным номером. Известно время размещения багажа в камеру хранения и время освобождения ячейки в камере хранения (в минутах с начала суток). Багаж достаётся из ячейки в течение минуты. Начиная со следующей минуты, в ячейку можно положить другой багаж. Если все ячейки заняты, то багаж сдать нельзя.

Входные данные:

В первой строке подается K  — число ячеек в камере хранения и N  — число пассажиров. На каждой из следующих N  строк записаны 2  числа: время размещения багажа в камере хранения и время освобождения ячейки в камере хранения.

Определите, какое количество багажей сдали в течение суток и номер ячейки, в которую положили последний сданный багаж.

Выходные данные:

В ответ через пробел запишите два числа: количество багажей, которые сдали в ячейки хранения и номер ячейки, в которую положили последний сданный багаж. Пример входных данных:

24 4

30 60

110 120

1000 2000

115 133

Для указанных входных данных ответом будет 4 1

Решение (Python)

f = open("26-2__2yr4z.txt")
# Считываем количество ячеек в камере хранения (K) и количество пассажиров (N)
k, n = map(int, f.readline().split())
# Создаем список для хранения времени сдачи и выдачи багажа каждого пассажира
# и считываем эти данные из файла, разделяя каждую строку на два числа
a = []
for i in range(n):
    start, finish = map(int, f.readline().split())
    a.append((start, finish))
# Инициализируем переменные для подсчета количества сданных багажей
# и для хранения номера последней занятой ячей
counter = 0
m = -1
# Создаем список для хранения состояния каждой ячейки (занята/свободна)
storage = [-1] * k
# Сортируем список пассажиров по времени сдачи багажа
a.sort()
# Проходим по каждому пассажиру
for i in range(n):
    start = a[i][0]
    finish = a[i][1]
    # Проходим по каждой ячейке в камере хранения
    for j in range(k):
        # Если время сдачи багажа текущего пассажира больше времени освобождения ячейки
        if start > storage[j]:
            # Занимаем текущую ячейку багажом пассажира
            storage[j] = finish
            # Увеличиваем счетчик сданных багажей
            counter += 1
            # Обновляем номер последней занятой ячейки
            m = j + 1
            # Прерываем внутренний цикл, чтобы перейти к следующему пассажиру
            break
# Выводим количество сданных багажей и номер последней занятой ячейки
print(counter, m)

 

Ответ: 5894 119
Оцените статью
Я решу все!