Форум программистов, компьютерный форум, киберфорум
Алгоритмы
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/15: Рейтинг темы: голосов - 15, средняя оценка - 4.60
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
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.01.2019, 17:35
Ответы с готовыми решениями:

Распил заготовки на бруски (детали)
моя задача написать программу, я использую следующий алгоритм 1. сперва беру заготовку 6000х160х160 мм 2. режу сперва по ширине 3....

из говна и палок (ФОТО)
предлагаю поделиться фоточками полезных девайсов, сделанных на коленке за полчаса. ну, чисто для смеха) начну со своего мини-солярия:...

3.6В LiFePO4 зарядка из ***** и палок. Критикуем!
Попалась на глаза данная схема. Господа, интересно услышать мнения знающих/ведующих.

13
 Аватар для Fulcrum_013
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  [ТС]
Цитата Сообщение от Fulcrum_013 Посмотреть сообщение
Только рюкзаков получается много а не один.
палки сортируются по убыванию остатки по возрастанию. Ну и дальше впихивается что куда впихнется. Т.е. наибольшая палка сравнивается с досками начиная с наименьшего остатка, когда найдена остаток оставшийся после ее обрезки вставляется в массив остатков с сохранением упорядоченности. По сути получается выбор минимального остатка куда влезет очередная палка. "т.е. первый подходящий с упорядочиванием" Основной из пользуемых в промышленности методов в силу своей простоты и достаточно высокой эффективности.
Это для вычисления необходимого количества досок. А как то можно сделать , чтобы получить "карту раскроя" - т.е. на какие размеры сколько пилить досок?
0
 Аватар для Fulcrum_013
2083 / 1574 / 169
Регистрация: 14.12.2014
Сообщений: 13,614
17.01.2019, 09:28
ЕвгенийАндреич, Ну вот именно карту раскроя так и определяют. При этом для ускорения вместо массива палок можно использовать кучу. Именно поэтому динамическую память и называют еще кучей - для ее "раскроя" тот же алгоритм оптимизации применяется. При этом на практике есть еще такое понятие как нижний предел размера остатка пригодный для дальнейшего использования. С учетом этого факта даже полный перебор если и дает выигрыш то редко и очень незначительный.
0
 Аватар для vantfiles
1018 / 1914 / 177
Регистрация: 07.05.2013
Сообщений: 3,931
Записей в блоге: 12
17.01.2019, 15:33
Вот тут было похожее обсуждение:

Задача на минимизацию остатков
0
1472 / 827 / 140
Регистрация: 12.10.2013
Сообщений: 5,456
17.01.2019, 15:50
Представьте цех 100 000 тон дерева в год и немного неоптимальный раскрой...

Лучше результата чем от брутофорс не существует с природе, его результат это эталон для всех других решений. Другое дело, что не всегда есть вычислительная мощность для него. Поэтому придумывают всякие уловки\усложнения\альтернативы.

Цитата Сообщение от ЕвгенийАндреич Посмотреть сообщение
и методом перебора (благо список не очень большой)
Смогли бы посчитать брутофорсом за это время пока выясняете тонкости другого подхода?
0
 Аватар для Fulcrum_013
2083 / 1574 / 169
Регистрация: 14.12.2014
Сообщений: 13,614
17.01.2019, 16:45
Цитата Сообщение от Excalibur921 Посмотреть сообщение
Лучше результата чем от брутофорс не существует с природе, его результат это эталон для всех других решений. Другое дело, что не всегда есть вычислительная мощность для него. Поэтому придумывают всякие уловки\усложнения\альтернативы.
Был у нас на городской олимпиаде в 90-х эта задача под названием "задача о нескольких рюкзаках" присутсвовала. Пройтить все тесты смогли только эти два метода - полный перебор рекурсией ака "брут" и "первый подходящий с упорядочиванием". Потому как НИИ Искуственного Интеллекта которое оную олимпиаду организовывало запарилось искать набор данных на которых брут превзошел бы. Хотя такие наборы данных действительно существуют.
0
 Аватар для vantfiles
1018 / 1914 / 177
Регистрация: 07.05.2013
Сообщений: 3,931
Записей в блоге: 12
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
 Аватар для Fulcrum_013
2083 / 1574 / 169
Регистрация: 14.12.2014
Сообщений: 13,614
22.01.2019, 21:16
Цитата Сообщение от ЕвгенийАндреич Посмотреть сообщение
кроит один в один как Базис Мебельщик раскрой
Реально это одна из первых лабораторок по курсу САПР в универе. Вернее ее половина. Вторая половина то же самое для 2D случая с прямоугольными листами и заготовками. Так что весь раскрой деланный "на скорую руку" работает именно так.
0
6180 / 945 / 313
Регистрация: 25.02.2011
Сообщений: 1,381
Записей в блоге: 1
21.05.2019, 09:04
Цитата Сообщение от ЕвгенийАндреич Посмотреть сообщение
Как думаете? Если взять палку 2000, и методом перебора (благо список не очень большой) подставлять все комбинации с размерами из списка, выбрать оптимальную комбинацию, из списка вычесть палки которые в этой комбинации и прибавить к нужному количеству досок +1 . И так делать до тех пор, пока в списке с палками не останется ничего???
Это будет оптимальный вариант?
Это будет быстрый вариант решения, в большинстве случаев решение будет лучше, чем "жадным" алгоритмом.
Самое оптимальное решение задачи линейного раскроя можно найти с помощью линейного программирования.
Полный перебор (брутфорс), как правило не применим на реальных данных в виду длительности процесса.

PS:
ЕвгенийАндреич, Можете привести пример Ваших исходных данных (реальных)
У меня есть кое-какой опыт по линейному раскрою
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
21.05.2019, 09:04
Помогаю со студенческими работами здесь

собрать игровой пк из каках и палок
Доброго времени суток, товарищи! Есть старый комп с которого в течение года планируется переехать на новый. Скорее всего по итогу...

NAS для дома из грязи и палок
Добрый день! Т.к. санкции наступают, а практического опыта работы с linux практически нет, было решено из прошлых конфигов домашнего РС...

Зарядка для ноутбука из соплей и палок
Дино: Ноут который очень хочет 19в и 3.4а, трансформатор который дает 220->25в и амперов больше чем 4а. диодный мостик, кондер...

Задача оптимального раскроя: распил досок
Всем привет! Никак не могу разобраться с задачей. Требуются комплекты досок, каждый из которых состоит из 2 досок длиной 1,5 м и 5...

Рекурсивный распил доски, нужны комментарии к коду
Здравствуйте! Искал задачу в интернете о рекурсивном распиле доски. Нашел следующий код: #include <stdio.h> #include...


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
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 . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru