|
7 / 7 / 4
Регистрация: 07.07.2011
Сообщений: 583
|
||||||||||||||||||||||||||
Алгоритм разбиения на пары по тренеру/весу06.04.2018, 09:14. Показов 1052. Ответов 3
Метки нет (Все метки)
Здравствуйте. Нужно разбить участников соревнований так, чтобы
1. Ни один ученик одного тренера не стоял с учеником того же тренера если это возможно (главный приоритет -тренер) 2. Разница в весе между участниками в парах должна быть минимальна и максимальная разница в весе между участниками должна быть минимальной, например вот такое разбиение
В сети не чего не нашел, пришлось самому изобретать велосипед. Сперва сортировал таблицу по тренерам от меньшинства к большинству по количеству учеников (снимок 1), а потом по порядку с первого искал самых подходящих по весу и сперва искал тройки, потому как если сначала искать двойки то на тройку меньшинства может не хватить, но все равно при таком алгоритме попадается куча вариантов списков, в которых не находится лучший вариант. Можно отсортировать по весу от меньшинства к большинству и там уже искать подходящих по тренеру -но это тоже ни к чему не приведет -потому как наилучший вариант разбиения может начинаться с поиска самого подходящего не к наименьшему по весу, а к кому нибудь другому. Мозг уже сломал и постоянно возникают не видимые условия, при которых идеальный вариант не получается. //--------------------------------------------------------------------------------------------------------- Как вы думаете, при каком алгоритме можно найти идеальное разбиение, он существует? Что можете посоветовать?
0
|
||||||||||||||||||||||||||
| 06.04.2018, 09:14 | |
|
Ответы с готовыми решениями:
3
Функция разбиения чисел на пары Алгоритм разбиения ячеек в QTextTable Алгоритм разбиения средней точкой |
|
7 / 7 / 4
Регистрация: 07.07.2011
Сообщений: 583
|
|
| 06.04.2018, 15:31 [ТС] | |
|
Мне кажется если и есть решение, то его надо искать в сортировке по весу - сортировать таблицу по увеличению веса и сперва найти максимальные скачки в разнице участников, например в сортировке 40.40.40.42.42.45.45.45 максимальный скачок происходит после веса 42 к 45 (то есть 3), и это возможно минимальная "максимальная разница" в весе среди участников и именно на это место в списке нужно обратить внимание (сн1,2). Если до скачка количество записей четное (не 5 как в нашем случае, а например 6), то этот скачок можно избежать (если в списке нет троек, если есть - то избежать скачок можно при нечетном количестве участников до него и не четном количестве троек вмещающихся до скачка). Короче чтобы избежать максимальный скачок, все записи до него нужно разбить на пары/тройки, но опять таки тройки и двойки можно расположить и после скачка (если есть возможность) и там они могут быть ближе по весу. Как определить где тройкам лучше находиться -до или после скачка? Потом максимальных скачков может быть несколько как в таком случае поступать? Мы упростили задачу до предела -все участники одного тренера (или у каждого тренера только один ученик), а мозг уже взорвался. Представьте что будет, если мы начнем рассматривать несколько тренеров с произвольным количеством учеников у каждого.
На ум приходит только один вариант -перебрать все варианты и выбрать самый подходящий, это хорошо если участников не больше десяти - 10! вариантов, а если их 40 - это 1*2*3...40 вариантов - жизни не хватит ни какому компу и перебрать. Если действительно существует решение этой (на первый взгляд простой задачи), то как вы думаете -оно может быть относительно простым? Возможно все эти условия, которые я перечислил (и не перечислил) заменить каким то не большим количеством условий?
0
|
|
|
7 / 7 / 4
Регистрация: 07.07.2011
Сообщений: 583
|
|
| 06.04.2018, 15:41 [ТС] | |
|
И вообще, как найти все необходимые условия, выполняя которые можно прийти к данному решению? Этому где то учат?
0
|
|
|
7 / 7 / 4
Регистрация: 07.07.2011
Сообщений: 583
|
|||||||||||||||||||||
| 13.04.2018, 16:52 [ТС] | |||||||||||||||||||||
|
По части главного приоритета (тренер) нашел такое условие, следуя которому ученик одного тренера не станет с учеником того же тренера. Например есть 4 тренера (столбца) по 3 ученика у каждого (12 участников)
0
|
|||||||||||||||||||||
| 13.04.2018, 16:52 | |
|
Помогаю со студенческими работами здесь
4
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|
Настройки VS Code
Loafer 13.04.2026
{
"cmake. configureOnOpen": false,
"diffEditor. ignoreTrimWhitespace": true,
"editor. guides. bracketPairs": "active",
"extensions. ignoreRecommendations": true,
. . .
|
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2.
Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива.
Было так:. . .
|
|
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: реализовать контроль корректности заполнения дат назначения. . .
|
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html
Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
|
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
|
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях.
Задача: при копировании документа очищать определенные реквизиты и табличную. . .
|