26.06 Распределение объектов по местам (хранение багажа, парковки, кафе, гостиницы)
Ошибка.
Попробуйте повторить позже
Статград 25.04.23
На парковке имеется мест для легковых автомобилей и
мест для микроавтобусов. Приезжающий на парковку
автомобиль занимает любое свободное место соответствующего типа. При этом если свободных мест для легковых
автомобилей нет, то легковой автомобиль занимает свободное место, предназначенное для микроавтобуса, но микроавтобус
не может занять место, предназначенное для легкового автомобиля. Если подходящего места нет, автомобиль
уезжает.
Входные данные Первая строка входного файла содержит целое число – общее количество автомобилей, в
течение суток приехавших на парковку. Каждая из следующих
строк описывает один автомобиль и содержит
целых
числа и букву. Первое число означает время в минутах с начала суток, когда автомобиль прибыл на парковку,
второе – необходимую длительность стоянки в минутах. Буква означает тип автомобиля: A – легковой, B –
микроавтобус.
Гарантируется, что никакие два автомобиля не приезжают одновременно. Если время прибытия автомобиля совпадает со временем окончания стоянки другого автомобиля, вновь прибывший автомобиль может занять освободившееся место, если оно подходит ему по типу.
Выходные данные
В ответе запишите два целых числа через пробел: сначала количество легковых автомобилей, которые смогут припарковаться, затем – общее количество автомобилей (как легковых, так и микроавтобусов), которые уедут из-за отсутствия мест.
Решение (Python)
file = open(’26__1ux52.txt’) # считываем количество машин в файле count_cars = int(file.readline()) # считываем время прибытия, время стоянки # тип автомобиля заменяем на номер парковочного места, # с которого начинаются доступные для его типа автомобилей парковочные места cars = [list(map(int, i.replace(’A’,’0’).replace(’B’,’80’).split())) for i in file] cars.sort() # сортируем список # симулируем парковку, 80 мест для легковых, 20 - для микроавтобусов park = [[] for i in range(100)] # создаем симуляцию парковки all_cars_count = 0 # количество припаркованных машин любого вида count_cars_A = 0 # количество припаркованных легковых машин for i in cars: # перебор машин в списке # проходимся по парковочным местам, начиная с первого доступного места # для категории текущего автомобиля for j in range(i[2], 100): # если парковочное место пусто или время прибытия текущего автомобиля # больше, чем время уезда предыдущего автомобиля, if (not park[j]) or (i[0] >= park[j][-1][1] + park[j][-1][0]): park[j].append(i) # то размещаем текущий автомобиль на парковке all_cars_count += 1 # увеличиваем количество припаркованных машин любого вида if i[2] == 0: # если текущая машина - легковая count_cars_A += 1 # то увеличиваем счётчик припаркованных легковых машин break # сбрасываем цикл, чтобы перейти к следующей машине print(count_cars_A,count_cars - all_cars_count) # находим количество автомобилей, которые уехали # из-за отсутствия мест, как разницу между общим количеством автомобилей # и количеством автомобилей, которым удалось припарковаться
Специальные программы

Программа
лояльности v2.0
Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!
Крути рулетку и покупай курсы со скидкой, которая привязывается к вашему аккаунту.

Бесплатное онлайн-обучение
Для школьников из приграничных территорий России, проживающих в ДНР, ЛНР, Херсонской, Запорожской, Белгородской, Курской, Брянской областях и Крыму.

Налоговые вычеты
Узнай, как получить налоговый вычет при оплате обучения в «Школково».

Специальное предложение
для учителей
Бесплатный доступ к любому курсу подготовки к ЕГЭ, ОГЭ и олимпиадам от «Школково». Мы с вами делаем общее и важное дело, а потому для нас очень значимо быть чем-то полезными для учителей по всей России!

Вернём деньги за курс
за твою сотку на ЕГЭ
Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!