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

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

Войти
Регистрация
Восстановить пароль
 
NeRRouZ
4 / 4 / 0
Регистрация: 19.12.2010
Сообщений: 54
#1

Динамическое программирование - C++

05.11.2012, 12:30. Просмотров 629. Ответов 2
Метки нет (Все метки)

Подскажите что не так в решении.

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
#include <iostream>
#include <stdio.h>
using namespace std;
 
const int N = 5001;
 
int min(int a, int b)
{
    return a < b ? a : b;
}
 
int main()
{
/*  freopen("input.txt", "r", stdin);
    freopen("output.txt", "w", stdout);*/
    
    int a[N], b[N], c[N];
    int d[N];
    int i, n;
    
    cin>>n;
    for (int i = 0; i<n; i++)
        cin>>a[i]>>b[i]>>c[i];
    
    d[0] = a[0];
    d[1] = a[1];
    d[2] = min(a[1]+a[2], b[1]);
    
    for (i=3; i<n; i++)
        d[i] = min( d[i-1] + a[i], min( d[i-2] + b[i-1], d[i-3] + c[i-2] ) );
        
    /*  for (i=0; i<n; i++)
            cout<<d[i]<<endl;*/
            
    cout<<d[n-1]+d[0]<<endl;
    
return 0;
}
Вот условие задачи:
За билетами на премьеру нового мюзикла выстроилась очередь из N человек, каждый из которых хочет купить 1 билет. На всю очередь работала только одна касса, поэтому продажа билетов шла очень медленно, приводя «постояльцев» очереди в отчаяние. Самые сообразительные быстро заметили, что, как правило, несколько билетов в одни руки кассир продаёт быстрее, чем когда эти же билеты продаются по одному. Поэтому они предложили нескольким подряд стоящим людям отдавать деньги первому из них, чтобы он купил билеты на всех.

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

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

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

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

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

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

В выходной файл OUTPUT.TXT выведите одно число — минимальное время в секундах, за которое могли быть обслужены все покупатели.

Для теста 1:
5
5 10 15
2 10 15
5 5 5
20 20 1
20 1 1

Ответ 12

Для теста 2:
2
3 4 5
1 1 1
Ответ 4

Для теста 3:
4
1 10 10
2 3 4
2 3 4
2 3 4
ответ 5
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.11.2012, 12:30
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Динамическое программирование (C++):

Динамическое программирование! - C++
#include &lt;cstdio&gt; #include &lt;algorithm&gt; using namespace std; int a, n, m; int main() { scanf(&quot; %d %d&quot;, &amp;n,...

Динамическое программирование - C++
Не понимаю динамических структур, списков, работы с ними. Посоветуйте источник изучения. Что-то вроде того что написано здесь...

ДП Динамическое программирование - C++
ограничение времени на тест: 0.5 сек. ограничение памяти на тест: 65536 KB. Рассмотрим все строки длины N, состоящие только из букв...

Динамическое программирование - C++
Помогите пожалуйста,кто может, со следующими задачами, так как в С++ слабо разбираюсь, а к понедельнику надо сдать... 1. Определить...

Динамическое программирование - C++
народ помогите пожалуйста. есть задача Написать программу, позволяющую вычислить количество чисел, не содержащих нули, сумма цифр...

Динамическое программирование - C++
Мячик прыгает по лестнице, состоящей из N ступенек, строго сверху вниз. За один прыжок он может отпрыгнуть на не более M ступенек....

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
valeriikozlov
Эксперт C++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
05.11.2012, 15:35 #2
Цитата Сообщение от NeRRouZ Посмотреть сообщение
Подскажите что не так в решении.
Основная часть у Вас правильная:
Цитата Сообщение от NeRRouZ Посмотреть сообщение
C++
1
2
for (i=3; i<n; i++)
 d[i] = min( d[i-1] + a[i], min( d[i-2] + b[i-1], d[i-3] + c[i-2] ) );
а вот начало все портит:
Цитата Сообщение от NeRRouZ Посмотреть сообщение
C++
1
2
3
d[0] = a[0];
 d[1] = a[1];
 d[2] = min(a[1]+a[2], b[1]);
И Вы всегда учитываете время a[0] в итоговом результате:
Цитата Сообщение от NeRRouZ Посмотреть сообщение
C++
1
cout<<d[n-1]+d[0]<<endl;// d[0] ведь равно a[0]
А ведь может быть 1-ый человек купил билет не на себя, а сразу на 2-х, или сразу на 3-х.
Давайте так договоримся d[i] - это минимальное значение по времени, которое нужно на покупку билетов i+1 людям.
Тогда основная часть остается без изменений, а вот начало нужно переделать так:
C++
1
2
3
    d[0] = a[0];
    d[1] =min(a[1]+d[0], b[0]);
    d[2] = min(min(c[0], d[1]+a[2]), d[0]+b[1]));
вывод результата так:
C++
1
cout<<d[n-1]<<endl;
NeRRouZ
4 / 4 / 0
Регистрация: 19.12.2010
Сообщений: 54
05.11.2012, 17:12  [ТС] #3
аааа)))) точно, спасибо большое)))
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
05.11.2012, 17:12
Привет! Вот еще темы с ответами:

Динамическое программирование - C++
Есть такая задача: Дана схема стены, необходимо проверить можно ли построить данную стену заданным набором кирпичей. Кирпич высот 1, а...

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

Динамическое программирование - C++
Ограничение по времени: 2 секунды Ограничение по памяти: 256 мегабайт У Пети есть полоска бумаги, разделенная на N клеток. Он хочет...

Динамическое программирование - C++
На расстоянии n шагов от магазина стоит А. Каждую минуту он выбирает куда сделать шаг: к магазину или в противоположном направлении. ...


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

Или воспользуйтесь поиском по форуму:
Ответ Создать тему
Опции темы

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