|
0 / 0 / 1
Регистрация: 30.04.2014
Сообщений: 13
|
|
Рассфассовка шаров по коробкам03.09.2017, 17:20. Показов 920. Ответов 5
Метки нет (Все метки)
Приветствую участников форума!
На входе имеем массив из чисел: in = [11, 8, 2, 5, 22, 2, 4, 4, 9, 12, 16, 13, 3] Нужно разбить этот массив на массивы, чтобы каждый содержал элементы, в сумме которые не выходят за границы нижнего и верхнего пределов(к примеру: 25-30), а оставшиеся элементы отбросить. Если приводить аналогию с реальным миром то: Имеется куча шаров разного объема, из необходимо рассфасовать по коробкам определенного размера, а оставшиеся шары выкинуть. На выходе: out = [ [11, 8, 4, 4], //= 27 [22, 2, 3], //= 27 [12, 16], //= 28 [13, 9, 5], //= 27 [2] //= остаток, отброс ] У меня уже есть эта функция, и она работает не так ка нужно, взять хотя-бы эту двойку в остатке, ее можно положить в любой из массивов и он не выйдет за пределы верхней границы. В школе у меня с математикой туговато было, тем не менее у меня вызывает любопытство, возможно ли разработать мат-формулу на основе этих данных, а затем уже на основе этой формулы написать программу?
0
|
|
| 03.09.2017, 17:20 | |
|
Ответы с готовыми решениями:
5
В урне содержится 8 шаров и 6 белых шаров. Случайным образом вынимают 4 шара Написать программу по расчету объема шаров разных диаметров (количество шаров заранее неизвестно) Найти скорость шаров после столкновения и изменение кинетической энергии шаров в результате удара. |
|
Айлурофил
|
|
| 04.09.2017, 02:20 | |
|
Это задача на разновидности диофантовых уравнений и неравенств, которые в общем случае аналитически не решаются.
0
|
|
|
0 / 0 / 1
Регистрация: 30.04.2014
Сообщений: 13
|
|
| 04.09.2017, 14:20 [ТС] | |
|
Мне кажется эта задача больше похожа на https://ru.wikipedia.org/wiki/... 0%ED%F6%E5.
Первым делом - нужно найти кол-во коробок для рассфасовки: сумма всех элементов массива in = [11, 8, 2, 5, 22, 2, 4, 4, 9, 12, 16, 13, 3] равна 111, это число поделить на нижнюю границу предела - 25, равно 4 (при целочисленном делении). И затем мне нужно как-то рассфасовать причем это сделать максимально сбалансированно, так сказать утрести. Вот здесь похожая проблема, якобы задача сводиться к нахождению четности элементов.
0
|
|
|
Модератор
3136 / 2283 / 469
Регистрация: 26.03.2015
Сообщений: 8,886
|
|||
| 04.09.2017, 15:02 | |||
|
(Например, если верхняя граница 200, то достаточно одной коробки). Добавлено через 8 минут [11, 8, 2, 5, 22, 2, 4, 4, 9, 12, 16, 13, 3] [22, 16, 13, 12, 11, 9, 8, 5, 4, 4, 3, 2, 2] [22, 8], [16, 13], [12, 11, 5, 2], [9, 4, 4, 3, 2]
1
|
|||
|
0 / 0 / 1
Регистрация: 30.04.2014
Сообщений: 13
|
|
| 04.09.2017, 15:29 [ТС] | |
|
Shamil1,
Да действительно, если честно то я уже стал брать во внимание только максимальную границу для решения задачи. Еще пришла идея, такая: 1) Отсортировать исходный массив in = [22, 16, 13, 12, 11, 9, 8, 5, 4, 4, 3, 2, 2] 2) Вложить последовательно в каждую коробку максимальные элементы in = [11, 9, 8, 5, 4, 4, 3, 2, 2] out = [ [22], [16], [13], [12] ] 3) Затем в цикле добавлять следующий элемент массива in в массив out, туда, где сумма элементов минимальная: //->iter(1) in = [9, 8, 5, 4, 4, 3, 2, 2] out = [ [22], [16], [13], [12, 11] ] //->iter(2) in = [8, 5, 4, 4, 3, 2, 2] out = [ [22], [16], [13, 9], [12, 11] ] //->iter(3) in = [5, 4, 4, 3, 2, 2] out = [ [22], [16, 8], [13, 9], [12, 11] ] //->iter(4) in = [4, 4, 3, 2, 2] out = [ [22, 5], [16, 8], [13, 9], [12, 11] ] //->iter(5) in = [4, 3, 2, 2] out = [ [22, 5], [16, 8], [13, 9, 4], [12, 11] ] //->iter(5) in = [3, 2, 2] out = [ [22, 5], [16, 8], [13, 9, 4], [12, 11, 4] ] //->iter(6) in = [2, 2] out = [ [22, 5], [16, 8, 3], [13, 9, 4], [12, 11, 4] ] //->iter(7) in = [2] out = [ [22, 5], [16, 8, 3], [13, 9, 4, 2], [12, 11, 4] ] //->iter(8) in = [] out = [ [22, 5, 2], // 29 [16, 8, 3], // 27 [13, 9, 4, 2], // 28 [12, 11, 4] // 27 ] Решение не идеальное но на замену того что у меня уже есть - достаточно, к тому же время здесь линейное Добавлено через 2 минуты А ну вот, похоже мы говорим об одном и том же, об жадном алгоритме.
0
|
|
|
Модератор
3136 / 2283 / 469
Регистрация: 26.03.2015
Сообщений: 8,886
|
||
| 04.09.2017, 16:58 | ||
|
0
|
||
| 04.09.2017, 16:58 | |
|
Помогаю со студенческими работами здесь
6
Вытаскивание всех шаров по порядку случайным образом из мешка, где 50 белых и 50 черных шаров Сколько шаров надо вытащить, чтобы с определенной уверенностью оценить долю шаров каждого цвета В двух урнах по 5 белых шаров и по 10 черных шаров В двух урнах по 5 белых шаров и по 10 черных шаров Найти вероятность того, что студент достал 5 одинаковых шаров / 5 шаров среди которых шары двух цветов Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Оттенки серого
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
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд.
Даже если у вас. . .
|