Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.95/103: Рейтинг темы: голосов - 103, средняя оценка - 4.95
10 / 1 / 0
Регистрация: 08.05.2021
Сообщений: 31

Покупка билетов

15.05.2021, 15:29. Показов 22319. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
За билетами на премьеру нового мюзикла выстроилась очередь из N человек, каждый из которых хочет купить 1 билет. На всю очередь работала только одна касса, поэтому продажа билетов шла очень медленно, приводя «постояльцев» очереди в отчаяние. Самые сообразительные быстро заметили, что, как правило, несколько билетов в одни руки кассир продаёт быстрее, чем когда эти же билеты продаются по одному. Поэтому они предложили нескольким подряд стоящим людям отдавать деньги первому из них, чтобы он купил билеты на всех.

Однако для борьбы со спекулянтами кассир продавала не более 3 билетов в одни руки, поэтому договориться таким образом между собой могли лишь 2 или 3 подряд стоящих человека.

Известно, что на продажу i-му человеку из очереди одного билета кассир тратит Ai секунд, на продажу двух билетов — Bi секунд, трёх билетов — Ci секунд. Напишите программу, которая подсчитает минимальное время, за которое могли быть обслужены все покупатели.

Обратите внимание, что билеты на группу объединившихся людей всегда покупает первый из них. Также никто в целях ускорения не покупает лишних билетов (то есть билетов, которые никому не нужны).

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

На вход программы поступает сначала число N — количество покупателей в очереди (1≤N≤5000). Далее идут N троек натуральных чисел Ai, Bi, Ci. Каждое из этих чисел не превышает 3600. Люди в очереди нумеруются, начиная от кассы.

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

Требуется вывести одно число — минимальное время в секундах, за которое могли быть обслужены все покупатели.
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
n=int(input())
p=[]
for i in range(n):
    p.append(list(map(int,input().split())))
a=[p[i][0] for i in range(len(p))]
b=[p[i][1] for i in range(len(p))]
c=[p[i][2] for i in range(len(p))]
d=[0]* (n+1)
d[1]=a[0]
d[2]=min(a[0]+a[1],b[0])
d[3]=min(d[2]+a[2],d[1]+b[1],c[0])
for i in range(n+1):
    if i>=4:
        d[i]=(min(d[i-1]+a[i-1],d[i-2]+b[i-2],d[i-3]+c[i-3]))
print(d[n])
можете помочь, почему-то не проходит...
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.05.2021, 15:29
Ответы с готовыми решениями:

С какого посещения кинотеатра # покупка билетов по системе B будет выгоднее системы A
# Существует 2 системы покупки билетов в кино. # Система А: ticket долларов за билет каждый раз # Система B: card долларов за карту,...

Выгодная покупка
Я учусь в Яндекс Лицее и у меня возникла проблема с задачей. Вот условие: Вам дан файл в формате csv с ценами на товары некоторого...

Выгодная покупка
Пётр хочет купить набор школьных учебников подешевле. Но у него не очень много времени, поэтому он намерен приобрести все книги в одном...

5
3 / 2 / 1
Регистрация: 08.10.2020
Сообщений: 19
15.05.2021, 17:44
У меня что-то такое получилось, колхоз конечно, но работает

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
def min_time(N, Ai, Bi, Ci):
    if N < 1:
        return "Количество покупателей введено неверно."
    if N == 2:
        return Bi
    if N % 3 == 0:
        return (N // 3) * Ci
    if N % 2 == 0:
        return (N // 3) * Ci + Ai
    if (N - 1) % 3 == 0:
        return (N // 3) * Ci + Ai
    if (N - 1) % 2 == 0:
        return (N // 3) * Ci + Bi
 
 
N = int(input("Введите количество покупателей: "))
print("Минимальное время обслуживания -", min_time(N, 1, 2, 3), "секунд.")
Добавлено через 6 минут
я уже понял, что неверно прочитал условие, но сообщение удалить нельзя
0
2 / 2 / 1
Регистрация: 08.05.2019
Сообщений: 2
16.05.2021, 19:08
Лучший ответ Сообщение было отмечено mik-a-el как решение

Решение

Ваша программа не работает если покупателей меньше 3, надо просто добавить условия для d[2] и d[3]
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
n = int(input())
p = []
for i in range(n):
    p.append(list(map(int, input().split())))
a = [p[i][0] for i in range(len(p))]
b = [p[i][1] for i in range(len(p))]
c = [p[i][2] for i in range(len(p))]
d = [0] * (n+1)
d[1] = a[0]
if n > 1:
    d[2] = min(a[0]+a[1], b[0])
if n > 2:
    d[3] = min(d[2]+a[2], d[1]+b[1], c[0])
for i in range(n+1):
    if i >= 4:
        d[i] = (min(d[i-1]+a[i-1], d[i-2]+b[i-2], d[i-3]+c[i-3]))
print(d[n])
2
Эксперт Python
1356 / 653 / 207
Регистрация: 23.03.2014
Сообщений: 3,057
17.05.2021, 00:20
Шазам)
Python
1
2
print(min([5, 10, 15][0] + min([2, 10, 15][0] + min([5, 5, 5][0] + min([20, 20, 1][0] + [20, 1, 1][0], [20, 20, 1][1]), [5, 5, 5][1] + [20, 1, 1][0], [5, 5, 5][2]), [2, 10, 15][1] + min([20, 20, 1][0] + [20, 1, 1][0], [20, 20, 1][1]),
      [2, 10, 15][2] + [20, 1, 1][0]), [5, 10, 15][1] + min([5, 5, 5][0] + min([20, 20, 1][0] + [20, 1, 1][0], [20, 20, 1][1]), [5, 5, 5][1] + [20, 1, 1][0], [5, 5, 5][2]), [5, 10, 15][2] + min([20, 20, 1][0] + [20, 1, 1][0], [20, 20, 1][1])))
0
0 / 0 / 0
Регистрация: 19.01.2024
Сообщений: 1
19.01.2024, 14:08
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
N = int(input())
times = []
 
for i in range(N):
  times.append(list(map(int, input().split())))
a = [times[i][0] for i in range(len(times))]
b = [times[i][1] for i in range(len(times))]
c = [times[i][2] for i in range(len(times))]
d = [0] * (N+1)
d[1] = a[0]
 
if N > 1:
  d[2] = min(a[0]+a[1], b[0])
if N > 2:
  d[3] = min(d[2]+a[2], d[1]+b[1], c[0])
 
for i in range(N+1):
  if i >=4:
    d[i] = (min(d[i-1]+a[i-1], d[i-2]+b[i-2], d[i-3]+c[i-3]))
 
print(d[N])
0
10 / 10 / 0
Регистрация: 05.04.2023
Сообщений: 47
27.07.2024, 20:23
Python
1
2
3
4
5
6
7
8
9
10
11
n=int(input())
s=[]
t=[]
t.append(0)
for i in range(n):
    s.append(list(map(int,input().split())))
t.append(s[0][0])
if n>1: t.append(min(s[0][0]+s[1][0],s[0][1]))
for i in range(3,n+1):
    t.append(min(t[i-1]+s[i-1][0],t[i-2]+s[i-2][1],t[i-3]+s[i-3][2]))
print(t[-1])
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.07.2024, 20:23
Помогаю со студенческими работами здесь

Покупка сложных задач
Доброе время суток! Помогите пожалуйста решить задачу: Николаю снова требуется помощь. На этот раз он решил купить как можно больше...

Код по продажам билетов
Всем доброго времени суток! Помогите пожалуйста разобраться в самом коде. Есть элементарная задача: Необходимо написать код по продажам...

Рассчитать стоимость билетов
Здравствуйте! Не знаю как реализовать данную задачу, буду благодарна за помощь! Во второй части программы необходимо реализовать...

Написать программу, проверяющую, возможна ли покупка
Некто располагает суммой в А руб. Он хочет купить В книг по С руб. и D журналов по Е руб. Написать программу, проверяющую, возможна ли...

Функции: расчет стоимости билетов на фильм
Здравствуйте,нужна помощь с функциями в Python))) Задание: Напишите функцию согласно варианту. Разместите ее в отдельном модуле. ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru