IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения.
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> Задача о рюкзаке методом ДП
сообщение
Сообщение #1





Группа: Пользователи
Сообщений: 4
Пол: Мужской

Репутация: -  0  +


Привет всем. Совсем потерял и покой и сон.
Никак не могу сделать эту задачу. Задача называется -задача о рюкзаке на паскале методом динамического программирования. Смысл: Есть рюкзак заданного размера например 70, есть 4 предмета которые имеют свой вес и стоимость. Необходимо забить рюкзак предметами чтобы общий вес их вмещался в рюкзак а стоимость при этом была наибольшей. т.е как бы из кучи разных вариантов выбрать оптимальный. но тем не мение выводит на экран все наборы т.е ход мыслей программы нужно отобразить. нашел несколько кодов но не один толком не работает. Вот к примеру такой:

Код

program rukzak_perebor;
const maxn=20;{?}
var n,w:integer;
weight,price:array[1..maxn]of integer;
best,now:array[1..maxn]of integer;
maxprice:longint;
procedure init;
var i:integer;
begin
read(n);
read(w);
for i:=1 to n do read(weight[i]);
for i:=1 to n do read(price[i]);
end;
procedure rec(k,w:integer;st:longint);
var i:integer;
begin
if (k>n) and (st>maxprice) then
begin
best:=now;
maxprice:=st;
end else
if k<=n then
for i:=0 to w div weight[k] do
begin
now[k]:=i;
rec(k+1,w-i*weight[k],st+i*price[k]);
end;
end;
begin
init;
rec(1,w,0);
writeln(' ',maxprice);
end.




Не работает совсем. В чем дело понять не могу. чуствую дело скоро дойдет до глюкозы
Помогите пожалуйста.
.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
сообщение
Сообщение #2


Профи
****

Группа: Пользователи
Сообщений: 652
Пол: Мужской
Реальное имя: Алексей

Репутация: -  20  +


Ну не изуродовал,он просто ее так криво скопировал,а что не работает действительно не понятно,задача 1 в 1 с той что тебе надо и задача делает именно то,что от нее и требуеца.
Т
ебе не нравица,что ты руками должен вводить?Или тебе надо выводить промежуточные результаты?И что за знак вопроса около описания константы?если тебе непонятно зачем это,то почитай ,как реализуется массив в паскале.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #3





Группа: Пользователи
Сообщений: 4
Пол: Мужской

Репутация: -  0  +


Цитата(Krjuger @ 22.06.2009 13:34) *

Ну не изуродовал,он просто ее так криво скопировал,а что не работает действительно не понятно,задача 1 в 1 с той что тебе надо и задача делает именно то,что от нее и требуеца.
Т
ебе не нравица,что ты руками должен вводить?Или тебе надо выводить промежуточные результаты?И что за знак вопроса около описания константы?если тебе непонятно зачем это,то почитай ,как реализуется массив в паскале.


Да я ничего сам честно говоря не уродовал. А именно скопировал если покопать могу сказать где.
Вот программа которая лежит по ссылке я немного добавил "дружественный интерфейс" smile.gif а то немного запутался с черным экраном.
Код

program rukzak_perebor;
const maxn = 20;
var
    n, w: integer;
    weight, price: array[1 .. maxn] of integer;
    best, now: array[1 .. maxn] of integer;
    maxprice: longint;

procedure init;
var i: integer;
begin
writeln('Enter the number of items: ');
    read(n);
writeln('Enter the total weight: ');    
    read(w);
    for i:=1 to n do begin
writeln('Enter the', i, 'element weight: ');
    read(weight[i]);
    end;
    for i:=1 to n do begin read(price[i]);
    writeln('Enter the', i, 'element price: ');
    end;
end;

procedure rec(k, w: integer; st: longint);
var i: integer;
begin
    if (k>n) and (st>maxprice) then begin
        best:=now;
        maxprice:=st;
    end
    else
        if k<=n then
            for i:=0 to w div weight[k] do begin
                now[k]:=i;
                rec(k+1,w-i*weight[k],st+i*price[k]);
            end;
end;

begin
    init;
    rec(1, w, 0);
    writeln('   ',maxprice);
end.


А как сделать её ДП? Что необходимо добавить?
Цитата

Тебе не нравица,что ты руками должен вводить?Или тебе надо выводить промежуточные результаты?И что за знак вопроса около описания константы?если тебе непонятно зачем это,то почитай ,как реализуется массив в паскале.


Нет. Мне все подходит. Да мне нужно чтоб выводились промежуточные вычисления. Знак вопроса скопировал вместе с кодом - он не из вашего FAQ я не помню где достал.
Помогите доработать под нужды а?



Сообщение отредактировано: BCW -
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 





- Текстовая версия 9.05.2024 6:55
500Gb HDD, 6Gb RAM, 2 Cores, 7 EUR в месяц — такие хостинги правда бывают
Связь с администрацией: bu_gen в домене octagram.name