1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
| BCW |
22.06.2009 9:28
Сообщение
#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. Не работает совсем. В чем дело понять не могу. чуствую дело скоро дойдет до глюкозы Помогите пожалуйста. . |
![]() ![]() |
| Krjuger |
23.06.2009 16:08
Сообщение
#2
|
|
Профи ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 652 Пол: Мужской Реальное имя: Алексей Репутация: 20 |
Не совершай моих ошибок,не путай динамическое програмирование и динамические структуры.насчет массива,который будет хранить промежуточные значения..,если ты возьмеш массив равный количеству возможных комбинаций,то ты не прогадаеш))),другое дело что для уже 10 вещей,паскаль не позволит создать массив,чтобы хранить все комбинации.Насчет ДП было конкретно сказано,что ты свою задачу разбиваеш на подзадачи.Вот тебе вариант подзадачи,просто найти комбинацию,которая влазит в твой мешок.Затем береш функцию,которая посчитает сумарную стоимость этих вещей,затем процедуту,которая будет проверять,есть ли данная стоимость в массиве результатов,и если нету,то записывать в массив.В итоге основная программа будет просто выбирать из твоего массива наибольшее число.
Я не совсем уверен,что это ДП,да и некоторые действия можно обьеденить в одну процедуру например.В общем это лиш идея того,как можно реализовать. Цитата Т.е получается рекурсию нужно убрать? А на что заменить? Цитата Например, для рюкзака можно написать такую рекурсию: Код function f(m, w) если f еще не была посчитана считаем и запоминаем возвращаем А можно просто выбрать такой порядок обхода, чтобы мы всегда обращались к уже посчитанным значениям. В нашем случае это будет обход слева-направо, сверху вниз: Код for m for w f:=... Плохо ты читал,видно надо еще пару раз прочитать и переосознать. Сообщение отредактировано: Krjuger - 23.06.2009 16:09 |
BCW Задача о рюкзаке методом ДП 22.06.2009 9:28
Lapp Решение есть вот тут: Переборные Алгоритмы
Только ... 22.06.2009 10:38
Lapp Стоп. Так это же ты прогу из нашего FAQ'а изу... 22.06.2009 11:07
Krjuger Ну не изуродовал,он просто ее так криво скопировал... 22.06.2009 12:34
BCW
Ну не изуродовал,он просто ее так криво скопирова... 22.06.2009 14:05
Krjuger Эм,извини но я не понимаю,тебе промежуточные резул... 22.06.2009 18:56
Lapp тут тоже есть фак
[url=http://forum.pascalnet.ru/i... 23.06.2009 0:44
Krjuger LapДа работает та программа,может быть не совсем д... 23.06.2009 11:18
BCW
LapДа работает та программа,может быть не совсем ... 23.06.2009 15:21![]() ![]() |
|
Текстовая версия | 13.12.2025 9:13 |