На производстве штучных изделий N деталей должны быть отшлифованы и окрашены. Для каждой детали известно время ее шлифовки и время окрашивания. Детали пронумерованы начиная с единицы. Параллельная обработка деталей не предусмотрена. На ленте транспортера имеется N мест для каждой из N деталей. На ленте транспортера детали располагают по следующему алгоритму:
– все 2N чисел, обозначающих время шлифовки и окрашивания для N деталей, упорядочивают по возрастанию;
– если максимальное число в этом упорядоченном списке – это время шлифовки конкретной детали, то деталь размещают на ленте транспортера на первое свободное место от ее начала;
– если максимальное число – это время окрашивания, то деталь размещают на первое свободное место от конца ленты транспортера;
– если число обозначает время окрашивания или шлифовки уже рассмотренной детали, то его не принимают во внимание.
Этот алгоритм применяется последовательно для размещения всех N деталей.
Определите время обработки детали, которая в итоге будет стоять на ленте транспортера на 168 месте, а также суммарное время окрашивания деталей.
Входные данные представлены в файле 26-3.txt следующим образом. Первая строка входного файла содержит натуральное число N – количество деталей. Следующие N строк содержат пары чисел, обозначающих соответственно время шлифовки и время окрашивания конкретной детали (все числа натуральные, различные).
Запишите в ответе два натуральных числа через пробел: сначала время обработки детали, которая в итоге будет стоять на ленте транспортера на 168 месте, а затем суммарное время окрашивания деталей.
f = open(’26_3__3whrj.txt’)
n = int(f.readline())
a = [list(map(int, i.split())) for i in f]
t = [] # список для хранения времени, типа операции и номера на ленте для каждой детали
for i in range(n):
if a[i][0] > a[i][1]:
t.append([a[i][0], 1, i + 1])
else:
t.append([a[i][1], 2, i + 1])
t.sort(reverse=True)
lenta = []
line_start = [] # списки для хранения деталей, которые размещаются в начале
line_end = [] # списки для хранения деталей, которые размещаются в конце
for i in t: # заполнение списков в зависимости от типа операции
if i[1] == 1:
line_start.append(i)
else:
line_end.append(i)
lenta = line_start + line_end[::-1]
print(lenta[167][0], sum(x[0] for x in line_end))