Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
newyork7776
347 / 340 / 79
Регистрация: 21.05.2013
Сообщений: 1,305
Завершенные тесты: 1
#1

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

02.12.2013, 19:06. Просмотров 379. Ответов 0
Метки нет (Все метки)

За билетами на премьеру нового мюзикла выстроилась очередь из N человек, каждый из которых хочет купить 1 билет. На всю очередь работала только одна касса, поэтому продажа билетов шла очень медленно, приводя «постояльцев» очереди в отчаяние. Самые сообразительные быстро заметили, что, как правило, несколько билетов в одни руки кассир продаёт быстрее, чем когда эти же билеты продаются по одному. Поэтому они предложили нескольким подряд стоящим людям отдавать деньги первому из них, чтобы он купил билеты на всех.
Однако для борьбы со спекулянтами кассир продавала не более 3-х билетов в одни руки, поэтому договориться таким образом между собой могли лишь 2 или 3 подряд стоящих человека.
Известно, что на продажу i-му человеку из очереди одного билета кассир тратит Ai секунд, на продажу двух билетов — Bi секунд, трех билетов — Ci секунд. Напишите программу, которая подсчитает минимальное время, за которое могли быть обслужены все покупатели.
Обратите внимание, что билеты на группу объединившихся людей всегда покупает первый из них. Также никто в целях ускорения не покупает лишних билетов (то есть билетов, которые никому не нужны).
IN = сначала число N — количество покупателей в очереди (1≤N≤5000). Далее идет N троек натуральных чисел Ai, Bi, Ci. Каждое из этих чисел не превышает 3600. Люди в очереди нумеруются начиная от кассы..
OUT = выведите одно число — минимальное время в секундах, за которое могли быть обслужены все покупатели.
Я вот набросал но у меня на Сайте пишет что 47/49
во мой код програмки
Кликните здесь для просмотра всего текста
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#include <iostream>
#include <algorithm>
using namespace std;
 
int minThree(int a,int b,int c){
    
    if(a <= b && a <= c){
        return a;
    }
    else if(a >= b && c >= b){
        return b;
    }
    else if(c <= a && c <= b){
        return c;
    }
}
int main()
{
    int mas[5000][3],n,q,w,e,r,t,y;
    int sum[5000];
    cin >> n;
    for(int i=0;i<n;i++)
    {
        for(int j=0;j<3;j++)
        {
            cin >> mas[i][j];
        }
    }
        sum[0]=mas[0][0];
            q=min((mas[0][0]+mas[1][0]),(mas[0][1]));
            w=(mas[0][0]+mas[1][0]);
        sum[1]=min(q,w);
            q=min((mas[0][0]+mas[1][0]),(mas[0][1])+mas[2][0]);
            w=min((mas[1][0]+mas[2][0]),(mas[1][1])+mas[0][0]);
            e=(mas[0][0]+mas[1][0]+mas[2][0]);
            r=min((mas[0][0]+mas[1][0]+mas[2][0]),(mas[0][2]));
            y=minThree(q,w,e);
        sum[2]=min(y,r);
        for(int i=3;i<n;i++)
        {
            sum[i]=minThree((sum[i-1]+mas[i][0]),(sum[i-2]+mas[i-1][1]),(sum[i-3]+mas[i-2][2]));
        }
    cout << sum[n-1] << endl;
    system("pause");
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.12.2013, 19:06     Покупка билетов
Посмотрите здесь:

Задача: Покупка цветов - C++
Помогите решить задачу На День учителя Вася решил купить букет цветов. В магазине продаются ромашки по A рублей за штуку и гладиолусы...

Определить, какая покупка дешевле - C++
Люди , плз помогите :wall:=-O В 1992 г. пара носков стоила 105 руб., связка (12 пар) 1025 руб., а коробка (12 связок) 11400 руб. По...

Цикл. Продажа билетов - C++
Всем привет Короче вот что необходимо. 10 человек хотят купить билеты. За один раз они могут купить только 2 билета, т.е. если он хочет...

Информация по темам билетов - C++
Всем доброго времени суток. Готовлюсь к сессии, все шло хорошо, но тут увидел несколько билетов которые мне не знакомы и более того, ищу...

Cистема резервирования билетов авиакомпании - C++
Уважаемые Гуру! Помогите довести до ума этот код. Уже 3 часа сижу и никак к норме не могу привести, давно не занимался и сейчас каша в...

Система резервирования билетов авиакомпании - C++
Система резервирования билетов авиакомпании. Небольшая авиакомпания купила компьютеры для своей новой автоматизированной системы...

Определить количество счастливых билетов - C++
Имеется часть катушки с автобусными билетами. Номер билета 6-ти значный. Составить программу. определяющую кол-во счастливых билетов! Я...

Система резервирования билетов авиакомпании. - C++
Пишем Microsoft Visual Studio -&gt; Win32 Console Application -&gt; C++. Вот такая вот задачка: Система резервирования билетов...

Подсчитать общее количество «счастливых» билетов - C++
Подсчитать общее количество «счастливых» билетов. Билет имеет шестизначный номер и является счастливым, если сумма первых трех цифр равна...

Разработка системы резервирования и продажи билетов - C++
Доброе время суток господа программисты. Я полный ламер в программировании. Прошу помочь мне в нелегком деле. Надо разработать систему...

Найти количество счастливых билетов с 6-значными номерами - C++
Найти количество счастливых билетов в серии ABC, то есть с 6 - значными номерами вида ABCXXX, счастливым билет считается с номером ABCDEF,...

Система предварительной продажи билетов. Интересная программа) - C++
Программа для бронирования мест на каждом рейсе единственного самолета авиакомпании (его вместимость 10 мест). Программа должна отображать...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru