Оптимизация рассадки: алгоритм поиска наибольшего паросочетания

Задача рассадки мальчиков и девочек по парам, где каждый хочет сидеть со знакомым, сводится к поиску наибольшего паросочетания в двудольном графе. В таком графе вершины делятся на два множества (мальчики и девочки), а ребра соединяют только вершины из разных множеств (знакомые пары).
Оптимизация рассадки: алгоритм поиска наибольшего паросочетания
Изображение носит иллюстративный характер

Представленный алгоритм использует итеративный подход, начиная с любой непарной вершины. Если для вершины найдена пара, а партнер уже связан с другой вершиной, алгоритм пытается найти для нее альтернативного партнера через «цепную реакцию». Этот процесс поиска альтернативного партнера продолжается рекурсивно, пока не будет найдена свободная пара или не будет перебрано все доступные варианты. Алгоритм работает, пока не будут перебраны все вершины.

Ключевым моментом является использование массива match, чтобы фиксировать пары, и массива book, для отметки посещенных вершин в рамках текущей итерации. После успешного построения пары счетчик увеличивается на единицу. Эта итеративная процедура, по сути, находит так называемую удлиняющую цепочку.

Алгоритм находит наибольшее паросочетание, но для строгого доказательства его правильности требуются более формальные методы, такие как математическая индукция. Алгоритмическая сложность данного решения O(NM), где N — число вершин, а M — число ребер в графе. Приведенный алгоритм часто называют алгоритмом Куна, а не «венгерским», как ошибочно указано в тексте. Венгерский алгоритм применяется для решения задачи о назначениях или поиска паросочетания минимальной стоимости.


Новое на сайте

19989Шесть историй, которые умещаются на ладони 19986Как 30 000 аккаунтов Facebook оказались в руках вьетнамских хакеров? 19985LofyGang вернулась: как бразильские хакеры охотятся на геймеров через поддельные читы 19984Автономная проверка защиты: как не отстать от ИИ-атак 19983Взлом Trellix: хакеры добрались до исходного кода одной из ведущих компаний по... 19982Почему почти 3000 монет в норвежском поле перевернули представление о викингах? 19981Как поддельная CAPTCHA опустошает ваш счёт и крадёт криптовалюту? 19980Слежка за каждым шагом: как ИИ превращает государство в машину тотального контроля 19979Как хакеры грабят компании через звонок в «техподдержку» 19978Почему именно Нью-Йорк стал самым уязвимым городом восточного побережья перед... 19977Как одна команда git push открывала доступ к миллионам репозиториев 19976Зачем древние народы убивали ножами и мечами: оружие как основа власти 19975Как Python-бэкдор DEEPDOOR крадёт ваши облачные пароли незаметно? 19974Послание в бутылке: математика невозможного 19973Почему ИИ-инфраструктура стала новой целью хакеров быстрее, чем ждали все?
Ссылка