Прикреплённый файл «2012-12-07.bilety.py»

Загрузка

   1 #!/usr/bin/env python
   2 # coding: utf
   3 '''
   4     Покупка билетов. За билетами на премьеру нового мюзикла выстроилась очередь из N человек, каждый из которых хочет купить 1 билет. На всю очередь работала только одна касса, поэтому продажа билетов шла очень медленно, приводя «постояльцев» очереди в отчаяние. Самые сообразительные быстро заметили, что, как правило, несколько билетов в одни руки кассир продаёт быстрее, чем когда эти же билеты продаются по одному. Поэтому они предложили нескольким подряд стоящим людям отдавать деньги первому из них, чтобы он купил билеты на всех.
   5         Однако для борьбы со спекулянтами кассир продавала не более 3-х билетов в одни руки, поэтому договориться таким образом между собой могли лишь 2 или 3 подряд стоящих человека. 
   6     Известно, что на продажу i-му человеку из очереди одного билета кассир тратит Ai секунд, на продажу двух билетов — Bi секунд, трех билетов — Ci секунд. Напишите программу, которая подсчитает минимальное время, за которое могли быть обслужены все покупатели.
   7         Обратите внимание, что билеты на группу объединившихся людей всегда покупает первый из них. Также никто в целях ускорения не покупает лишних билетов (то есть билетов, которые никому не нужны). 
   8 
   9     Формат входных данных:
  10         Во входном файле записано сначала число N — количество покупателей в очереди (1≤N≤5000). Далее идет N троек натуральных чисел Ai, Bi, Ci. Каждое из этих чисел не превышает 3600. Люди в очереди нумеруются начиная от кассы. 
  11 
  12     Формат выходных данных
  13         В выходной файл выведите одно число — минимальное время в секундах, за которое могли быть обслужены все покупатели. 
  14 '''
  15 
  16 N=input("Введите длину очереди: ")
  17 
  18 # Как бы не договаривались предыдущие покупатели,
  19 # минимальное время F(i) для i-го покупателя выбирается из следующих вариантов:
  20 # F(i-3)+C[i-2]     последний в тройке
  21 # F(i-2)+B[i-1]     последний в паре
  22 # F(i-1)+A[i]       единоличник
  23 # варианты C[i-1], C[i] и B[i] требуют по условию наличия последующих покупателей,
  24 # поэтому их можно не считать на i-м шаге
  25 
  26 def mintime(N):
  27     '''Функция с вводом всей последовательности'''
  28     A,B,C=[],[],[]
  29     for i in xrange(N):
  30         a,b,c=raw_input().split()
  31         A.append(int(a))
  32         B.append(int(b))
  33         C.append(int(c))
  34     Min=[A[0]]
  35     Min.append(min(B[0],Min[0]+A[1]))
  36     Min.append(min(C[0],Min[0]+B[1],Min[1]+A[2]))
  37     for i in xrange(3,N):
  38         Min.append(min(Min[i-3]+C[i-2],Min[i-2]+B[i-1],Min[i-1]+A[i]))
  39     return Min[-1]
  40 
  41 def min3time(N):
  42     '''Функция с хранением только актуальных данных'''
  43     B1=C1=C2=3600+1
  44     F1=F2=F3=0
  45     for i in xrange(N):
  46         # Введём данные на i-го покупателя
  47         A,B,C=[int(i) for i in raw_input().split()]
  48         F=min(F3+C2,F2+B1,F1+A)
  49         # «Прокрутим» актуальные значения A,B,C и F
  50         F3,F2,F1,B1,C2,C1=F2,F1,F,B,C1,C
  51     return F
  52 
  53 print min3time(N)

Прикреплённые файлы

Для ссылки на прикреплённый файл в тексте страницы напишите attachment:имяфайла, как показано ниже в списке файлов. Не используйте URL из ссылки «[получить]», так как он чисто внутренний и может измениться.

Вам нельзя прикреплять файлы к этой странице.