Форум программистов, компьютерный форум, киберфорум
Prolog
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
swetry

Сложить камни в сумки [SWI Prolog]

12.12.2010, 14:30. Показов 1135. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
доброе время суток...помогите решить задачу на прологе. Цель задачи сложить камни в сумки. Дано: масса каждого из камней и вместимость каждой сумки. (Bin - Packing Problem) Возможно применить такой алгоритм : берём подряд сумки и смотрим есть ли ещё места и вкладываем камень. Дальше берём ещё один камень и проверяем сумки снова. Сеичас имею такой код:
Prolog
1
2
3
test([bin(Name, Capacity, List)|Bins], [Weight|Stones], Goal):-
 Capacity >= Weight, !, insert(Weight, List, ListNew), NewC is Capacity-Weight, test([bin(Name, NewC, ListNew)|Bins], Stones, Goal).
test([bin(_, Capacity, _)|Bins], [Weight|Stones], Goal) :- Capacity < Weight, test(Bins, [Weight|Stones], Goal).
Он вложив камень неподаёт всех сумок на проверку, а начинает от той в которую последнюю был вложен камень. Как я мог бы исправить код? Заранье спасибо.
резуьтат мог бы быть :
Prolog
1
 Goal=[bin(Name, Capacity, список вместившихся елементов(веса)), bin(...)...]
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.12.2010, 14:30
Ответы с готовыми решениями:

Как переделать программу написанную на Turbo-Prolog в SWI-Prolog?
Ребята подскажите пожалуйста как переделать эту программу написанную на Turbo-Prolog в SWI-Prolog? domains i=integer il=i* ...

В Turbo-Prolog есть возможность описать Goal. Как это реализовано в SWI-Prolog
Здравствуйте. в Turbo-Prolog есть возможность описать Goal: Goal father(X,_), write(X). И ответ мы получим сразу при запуске...

Перевод программы из Turbo Prolog в SWI-Prolog
Здравствуйте! У меня есть программа по определению внука Петра III, она написана на Turbo Prolog. Я пытался перевести её на SWI-Prolog,...

1
 Аватар для Грымзик
2507 / 1483 / 37
Регистрация: 14.09.2009
Сообщений: 2,740
12.12.2010, 22:10
Prolog
1
2
3
4
5
6
7
put_stone([bin(Name, Capacity, List)|Bins],Weight, [bin(Name,NewC,ListNew)|Bins]):-
    Capacity >= Weight, !, insert(Weight, List, ListNew),NewC is Capacity-Weight.
put_stone([Bin|Bins], Weight, [Bin|NewBins]) :- test(Bins, Weight, NewBins).
 
put_stones(Bins,[],Bins).
put_stones(Bins,[Weight|Stones],NewBins):-put_stone(Bins,Weight,TempBins),
    put_stones(TempBins,Stones,NewBins).
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.12.2010, 22:10
Помогаю со студенческими работами здесь

Swi Prolog
Ребята помогите решить задания по SWI Prolog: 1.В списке символов S1, S2, ..., Sn найти длину наибольшей последовательности,...

Логическая задача: Какого цвета фрукты, которые любят Бет и Мэри? [SWI Prolog]
Здравствуйте! Помоги пожалуйста с реализацией 4 запроса ( 4. Какого цвета фрукты, которые любят Бет и Мэри?) Мэри любит персики....

SWI-Prolog + Qt
Доброй ночи. Срочно нужна помощь. Есть небольшой проект на с++ в Qt, благодаря которому можно в окошке рисовать графы (точнее ребра и...

Программа для Turbo Prolog не работает в SWI Prolog
Скажите пожалуйста как работать в SWI Prolog...я работал на турбопролог, вот например есть там решенная задачка: PREDICATES ...

Задача на Swi-Prolog
Здравствуйте. В общем появилась проблема. Никогда не изучал пролог. И вот дали сделать задачку. Вообще не режу что и как там означает и как...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru