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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Составьте программу, которая вычисляет значения n-го слагаемого Q и суммы n слагаемых последовательности S (спасите) http://www.cyberforum.ru/cpp-beginners/thread688941.html
Задание на лабораторную работу: Для заданного преподавателем варианта задания составьте программу, которая вычисляет значения n-го слагаемого Q и суммы n слагаемых последовательности S. Входные данные: n – переменная целочисленного типа ( 0 < n < 10000 ), параметры последовательности a, x – переменные вещественного типа. Все входные данные вводятся с клавиатуры. Выходные данные: Q, S –...
C++ Выделение числовой константы из строки char * find-const ( ) , 1)помещает в буфер строки digit литеру буфера buf_lit, 2)из входного потока читает литеру за литерой,пока не встретит не цифру или конец файла; 3)усли счетная-цифра,то она помещается в очередную позицию буфера строки.Если это не цифра,то строка дополняется символом "\0 а литера остается в буфере buf-lit. Если буфер исчерпан,а на входе цифра,то чтение продолжается,пока... http://www.cyberforum.ru/cpp-beginners/thread688940.html
C++ Списки и наследование
добрый день. Есть класс связанного списка class A{ A* prev; A* next; int id; //прочие члены класса
C++ Как набраться опыта?
Здравствуйте, киберфорумчане хотелось бы вам задать вопрос как набраться опыта в С++? Я думаю что если читать книги и вникать то можно только научиться кодить а вот опыта где набраться фиг знает? Может какие нибудь задачи порешать? Где есть задачи чтоб по уровню были?
C++ Длинная арифметика(деление на 11) http://www.cyberforum.ru/cpp-beginners/thread688928.html
Здравствуйте имеется задача , в которой надо проверить делиться ли число на 11 ввод: любое число не больше чем 101000 вывод : да или нет например: ввод:4958439238923098349024 вывод: НЕТ
C++ Из инфиксной в постфиксную Привет, опять я с этим заданием. Уже глаз болит, не могу понять в чем беда. Проблема при использовании скобок. А если вводить что-то типа A+B-C то он теряет "-" bool stekNil( Stack^ stek, bool *flag,wchar_t q)//проверка на пустоту списка { *flag = false; if ( stek->Count == 0 ) { *flag = true; } else *flag = false; return *flag; подробнее

Показать сообщение отдельно
NeRRouZ
 Аватар для NeRRouZ
4 / 4 / 0
Регистрация: 19.12.2010
Сообщений: 54
05.11.2012, 12:30     Динамическое программирование
Подскажите что не так в решении.

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
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 08:01. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru