|
7 / 7 / 4
Регистрация: 07.07.2011
Сообщений: 583
|
||||||||||||||||||||||||||
Алгоритм разбиения на пары по тренеру/весу06.04.2018, 09:14. Показов 1036. Ответов 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
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Рецензия / Мнение
Это мой обзор планшета X220 с точки зрения школьника.
Недавно я решила попытаться уменьшить свой. . .
|
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
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|