|
0 / 0 / 0
Регистрация: 12.07.2018
Сообщений: 65
|
|
Оптимальный распил палок16.01.2019, 17:35. Показов 3351. Ответов 13
Метки нет (Все метки)
Д.в.
Нужен алгоритм для решения следующей задачи или если он есть, то как называется? Есть доски длинной 2000 мм. Есть список с досками от 300 мм до 1000 мм. Мне нужно написать программу (не важно на каком языке, мне главное алгоритм), которая считает сколько надо досок, чтобы напилить палки из списка с минимальным остатком, что бы сложить все остатки в одну сумму и получилось как можно меньше. ну и соответственно чтобы знать сколько палок надо распилить на какие размеры. Например 10 досок пилим на три палки - 600, 500 и 300, 4 доски пилим на 800 и 900, и т.д. Что можете предложить? Всю голову сломал. Есть алгоритм "Упаковки рюкзака", но там учитывается "цена" и "Вес", а мне как бы надо просто "вес". заранее спасибо тому кто что то подскажет) Добавлено через 16 минут Как думаете? Если взять палку 2000, и методом перебора (благо список не очень большой) подставлять все комбинации с размерами из списка, выбрать оптимальную комбинацию, из списка вычесть палки которые в этой комбинации и прибавить к нужному количеству досок +1 . И так делать до тех пор, пока в списке с палками не останется ничего??? Это будет оптимальный вариант?
0
|
|
| 16.01.2019, 17:35 | |
|
Ответы с готовыми решениями:
13
Распил заготовки на бруски (детали) из говна и палок (ФОТО) 3.6В LiFePO4 зарядка из ***** и палок. Критикуем! |
|
2083 / 1574 / 169
Регистрация: 14.12.2014
Сообщений: 13,614
|
||
| 16.01.2019, 17:58 | ||
Сообщение было отмечено ЕвгенийАндреич как решение
Решениепалки сортируются по убыванию остатки по возрастанию. Ну и дальше впихивается что куда впихнется. Т.е. наибольшая палка сравнивается с досками начиная с наименьшего остатка, когда найдена остаток оставшийся после ее обрезки вставляется в массив остатков с сохранением упорядоченности. По сути получается выбор минимального остатка куда влезет очередная палка. "т.е. первый подходящий с упорядочиванием" Основной из пользуемых в промышленности методов в силу своей простоты и достаточно высокой эффективности. Ну в общем то есть попытки его апгрейда которые в худшем случае работают не хуже. к примеру вот тут
1
|
||
|
1472 / 827 / 140
Регистрация: 12.10.2013
Сообщений: 5,456
|
|
| 16.01.2019, 23:14 | |
|
Лучше брутофорса ничто не решит. Другое дело хватит ли мощности =).
0
|
|
|
0 / 0 / 0
Регистрация: 12.07.2018
Сообщений: 65
|
||
| 17.01.2019, 08:07 [ТС] | ||
|
0
|
||
|
2083 / 1574 / 169
Регистрация: 14.12.2014
Сообщений: 13,614
|
|
| 17.01.2019, 09:28 | |
|
ЕвгенийАндреич, Ну вот именно карту раскроя так и определяют. При этом для ускорения вместо массива палок можно использовать кучу. Именно поэтому динамическую память и называют еще кучей - для ее "раскроя" тот же алгоритм оптимизации применяется. При этом на практике есть еще такое понятие как нижний предел размера остатка пригодный для дальнейшего использования. С учетом этого факта даже полный перебор если и дает выигрыш то редко и очень незначительный.
0
|
|
|
|
|
| 17.01.2019, 15:33 | |
|
0
|
|
|
1472 / 827 / 140
Регистрация: 12.10.2013
Сообщений: 5,456
|
||
| 17.01.2019, 15:50 | ||
|
Представьте цех 100 000 тон дерева в год и немного неоптимальный раскрой...
Лучше результата чем от брутофорс не существует с природе, его результат это эталон для всех других решений. Другое дело, что не всегда есть вычислительная мощность для него. Поэтому придумывают всякие уловки\усложнения\альтернативы.
0
|
||
|
2083 / 1574 / 169
Регистрация: 14.12.2014
Сообщений: 13,614
|
||
| 17.01.2019, 16:45 | ||
|
0
|
||
|
|
|
| 17.01.2019, 18:33 | |
|
Кстати, вопрос - это теоретическая задача или практическая?
На практике оптимизируя один заказ можно получить заметно больше отходов, чем оптимизируя несколько заказов. Если же заказы поступают раз в сутки, то лучше заложиться не на минимизацию отходов - а на "полезные остатки" - то есть обрезки, которые могут пригодиться в дальнейшем в других заказах.
1
|
|
|
0 / 0 / 0
Регистрация: 12.07.2018
Сообщений: 65
|
|
| 22.01.2019, 11:13 [ТС] | |
|
Fulcrum_013, спасибо. Работает. Написал программу по твоему алгоритму в VBA Excel, кроит один в один как Базис Мебельщик раскрой. Т.к. у меня все ведется в экселе не хотелось привлекать стороннею программу для раскроя, а так хоп хоп и все работает четко
0
|
|
|
1472 / 827 / 140
Регистрация: 12.10.2013
Сообщений: 5,456
|
|
| 22.01.2019, 17:00 | |
|
ЕвгенийАндреич, Для эксперимента не пробовали сверять с брутофорсом?
Критерии оценки: 1)размер остатков 2)кол-во строк кода. 3) разбор матана\кода метода
0
|
|
|
0 / 0 / 0
Регистрация: 12.07.2018
Сообщений: 65
|
|
| 22.01.2019, 20:17 [ТС] | |
|
Excalibur921, не пробовал, не когда. Я и так проэкт на долго затормозил. Когда закончу, буду его совершенствовать ,вот и попробую
0
|
|
|
2083 / 1574 / 169
Регистрация: 14.12.2014
Сообщений: 13,614
|
||
| 22.01.2019, 21:16 | ||
|
0
|
||
| 21.05.2019, 09:04 | ||
|
Самое оптимальное решение задачи линейного раскроя можно найти с помощью линейного программирования. Полный перебор (брутфорс), как правило не применим на реальных данных в виду длительности процесса. PS: ЕвгенийАндреич, Можете привести пример Ваших исходных данных (реальных) У меня есть кое-какой опыт по линейному раскрою
0
|
||
| 21.05.2019, 09:04 | |
|
Помогаю со студенческими работами здесь
14
NAS для дома из грязи и палок Зарядка для ноутбука из соплей и палок Задача оптимального раскроя: распил досок Рекурсивный распил доски, нужны комментарии к коду Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|