Решение нужно на PascalABC.NET
Лифт в N-этажном доме может перевозить одновременно не более L человек. Расстояние между этажами он проезжает за T секунд. Время на остановку на любом этаже с посадкой пассажира в лифт составляет P секунд. В начальный момент времени лифт без людей находится на последнем этаже (номер N). Одновременно K человек нажимают кнопки вызова на разных K этажах выше первого с целью уехать на 1-й этаж. Лифт едет вниз, останавливаясь на тех этажах, где была нажата кнопка вызова. При каждой остановке входит один человек. Если лифт заполнен, то дальше он едет без остановок. Требуется определить, через какой промежуток времени лифт доедет до первого этажа, а также номер самого высокого из этажей, на которых еще остались люди. Известно, что в течение всего времени новых вызовов или отмены вызовов не происходит.
Формат ввода:
Вначале вводятся целые числа N, L, T, P, K (1≤ N ≤100, 4≤ L ≤12, 1≤ T ≤10, 1≤ P ≤10, 1≤ K ≤100), затем K чисел от N до 2 каждое – номера этажей, с которых был сделан вызов, в порядке убывания.
Формат вывода
Выведите два целых числа: в первой строке количество секунд, через которое лифт доедет на 1-й этаж, во второй строке – номер самого высокого из тех этажей, на которых еще остались люди или NO, если в лифт поместились все желающие.