Проверка Гамильтонова Пути
Проверьте, содержит ли граф гамильтонов путь или гамильтонов цикл. Выполняет поиск с возвратом с отсечением Варнсдорфа, проверяет условия связности и степеней вершин, тестирует достаточные условия Дирака и Оре, и показывает найденный путь на анимированной SVG-визуализации.
Ваш блокировщик рекламы мешает показывать объявления
MiniWebtool бесплатен благодаря рекламе. Если этот инструмент помог, поддержите нас через Premium (без рекламы + быстрее) или добавьте MiniWebtool.com в исключения и обновите страницу.
- Или перейдите на Premium (без рекламы)
- Разрешите показ рекламы на MiniWebtool.com, затем перезагрузите страницу.
О Проверка Гамильтонова Пути
Проверка гамильтонова пути определяет, содержит ли граф гамильтонов путь — последовательность, посещающую каждую вершину ровно один раз — или гамильтонов цикл, который дополнительно возвращается в исходную вершину. Инструмент сочетает быстрые структурные проверки (связность, требования к степеням, теоремы Дирака и Оре) с поиском с возвратом, оптимизированным эвристикой Варнсдорфа, и визуализирует найденный путь с помощью пошаговой анимации.
Что такое гамильтонов путь?
Для заданного графа G = (V, E) с n вершинами гамильтонов путь — это упорядоченная последовательность v1, v2, …, vn всех вершин такая, что каждая последовательная пара (vi, vi+1) является ребром G, и каждая вершина встречается ровно один раз. Если дополнительно (vn, v1) является ребром, последовательность называется гамильтоновым циклом.
Задача названа в честь Уильяма Роуэна Гамильтона, который в 1857 году изобрел икосианскую игру — головоломку, в которой требовалось найти цикл, посещающий каждую вершину правильного додекаэдра ровно один раз.
Почему это сложно: NP-полнота
Задачи определения существования гамильтонова пути и гамильтонова цикла являются NP-полными (Карп, 1972). Если только P не равно NP, не существует алгоритма с полиномиальным временем работы, решающего любой экземпляр задачи. В худшем случае поиск с возвратом исследует дерево поиска размером до (n−1)! для цикла. Вот почему калькулятор ограничивает ввод 20 вершинами — небольшое полиномиальное увеличение n приводит к взрывному росту времени выполнения.
На практике эвристика Варнсдорфа (первоначально разработанная Генрихом Варнсдорфом в 1823 году для задачи о ходе коня) значительно ускоряет поиск на структурированных графах: на каждом шаге алгоритм продлевает текущий путь в ту непосещенную соседнюю вершину, которая имеет наименьшее количество собственных непосещенных соседей. Это жадное правило предотвращает попадание поиска в тупик и часто находит гамильтонов обход без единого возврата на «хороших» графах.
Необходимые условия — Быстрая отбраковка
Прежде чем запускать ресурсоемкий поиск, калькулятор отбраковывает графы, которые заведомо не могут содержать гамильтонов путь:
- Связность. Гамильтонов путь должен посещать каждую вершину, поэтому граф должен иметь ровно одну компоненту связности. Для ориентированных графов требуется слабая связность (без учета направления стрелок).
- Степень (неориентированный граф). Не более двух вершин могут иметь степень 1 — только они могут быть конечными точками пути. Для гамильтонова цикла каждая вершина должна иметь степень не менее 2.
- Степень (ориентированный граф). Для гамильтонова пути максимум одна вершина может иметь входящую степень 0 (начало) и максимум одна может иметь исходящую степень 0 (конец). Для гамильтонова цикла каждая вершина должна иметь как входящую, так и исходящую степень ≥ 1.
Эти правила позволяют за линейное время отсеять множество безнадежных вариантов, избегая напрасных усилий по поиску с возвратом.
Достаточные условия — Классические теоремы
Несколько классических теорем дают достаточные (но не необходимые) условия, гарантирующие наличие гамильтонова цикла в неориентированных простых графах. Если любое из них выполняется, калькулятор помечает результат как «ГАРАНТИРУЕТ» даже без запуска поиска (хотя цикл-свидетель всё равно будет показан).
Теорема Дирака (1952)
Если G — простой неориентированный граф с n ≥ 3 вершинами, и каждая вершина имеет степень не менее n / 2, то G имеет гамильтонов цикл.
Теорема Оре (1960)
Если для каждой пары несмежных вершин u и v выполняется deg(u) + deg(v) ≥ n, то G имеет гамильтонов цикл. Условие Оре строго слабее условия Дирака, поэтому из условия Оре следует условие Дирака.
Невыполнение условий Дирака или Оре не означает, что в графе нет гамильтонова цикла — многие графы не удовлетворяют ни одному из них, но всё же содержат цикл (например, простой n-цикл имеет минимальную степень 2, что намного меньше n/2 для больших n).
Алгоритм поиска внутри
Когда предварительные проверки не дают ответа, калькулятор запускает поиск с возвратом на представлении смежности графа. Ключевые тактики:
- Битовая маска посещенных вершин. Посещенные вершины хранятся в виде битовой маски (быстрая проверка принадлежности O(1) для графов до 20 вершин).
- Эвристика Варнсдорфа. При каждом расширении пути соседи перебираются в порядке их оставшейся степени посещаемости (сначала меньшие), имитируя порядок с низким ветвлением.
- Выбор корня. Для гамильтонова цикла достаточно начать с одной любой вершины (циклы инвариантны относительно вращения). Для гамильтонова пути начальные вершины пробуются в порядке возрастания исходящей степени — сначала наиболее редкие позиции.
- Лимит шагов. Жесткое ограничение предотвращает бесконечную работу на патологических случаях; в интерфейсе такой результат отображается как «тайм-аут».
Гамильтоновы задачи против Эйлеровых
Гамильтоновы и эйлеровы задачи часто путают — они звучат похоже, но фундаментально различаются:
| Свойство | Гамильтонов путь / цикл | Эйлерова цепь / цикл |
|---|---|---|
| Посещает каждую… | Вершину ровно один раз | Ребро ровно один раз |
| Сложность | NP-полная | Полиномиальная (O(n+m)) |
| Условие | Нет простой характеристики | Связность + все степени четные (для цикла); макс. 2 нечетных для цепи |
| Названо в честь | У. Р. Гамильтон (1857) | Л. Эйлер (1736, мосты Кёнигсберга) |
| Классический пример | Задача коммивояжера, икосианская игра | Инспекция дорог, задача почтальона |
Поддерживаемые форматы ввода
Список ребер
Одно ребро на строку или через запятую. Поддерживаемые разделители: A-B, A B, A,B, A--B, A->B, A<-B. Используйте -> для принудительного указания ориентации.
Матрица смежности
Квадратная матрица значений 0/1, одна строка на линию, разделенная пробелами или запятыми. Можно указать метки в соответствующем поле, иначе автоматически будут использованы A, B, C…
Как использовать эту проверку
- Выберите формат ввода — Список ребер для небольших графов, написанных от руки, или матрица смежности для вставки из кода или учебников.
- Вставьте ваш граф в текстовое поле. Для ввода матрицы можно дополнительно указать метки вершин.
- Выберите, что проверять: Только путь, Только цикл или Оба сразу.
- Выберите тип графа — Автоопределение определит ориентированность по стилю стрелок (
->) или симметрии матрицы. - Нажмите «Проверить гамильтонов путь». Страница результатов покажет вердикт, проверку необходимых условий, тесты Дирака / Оре, путь-свидетель (если он существует) и интерактивную визуализацию.
- Воспроизведите путь с помощью кнопок Пуск / Шаг. Наблюдайте, как путь подсвечивается на графе ребро за ребром.
Пример — Граф Петерсена
Знаменитый граф Петерсена (10 вершин, 15 ребер, 3-регулярный) — классический пример графа, имеющего гамильтонов путь, но не имеющего гамильтонова цикла. Вставьте это в поле списка ребер и нажмите «Проверить»:
Проверка подтвердит: гамильтонов путь найден (например, 1 — 2 — 7 — 10 — 5 — 4 — 9 — 6 — 8 — 3), но полный перебор показывает отсутствие возможности замкнуть цикл — результат, впервые доказанный в 1890-х годах.
Области применения
- Маршрутизация и задача коммивояжера — любой тур TSP является гамильтоновым циклом в полном взвешенном графе.
- Сборка генома — реконструкция последовательности ДНК из перекрывающихся фрагментов может быть смоделирована как гамильтонов путь в графе перекрытий.
- Трассировка печатных плат — упорядочивание выводов на плате для минимизации длины проводников.
- Игровой AI и решение головоломок — обход шахматной доски конем, икосианская игра.
- Планирование — построение последовательности задач так, чтобы переход от одной к другой был осуществим.
- Преподавание комбинаторики — демонстрация NP-полноты на небольших примерах, решаемых вручную.
Часто задаваемые вопросы
Что такое гамильтонов путь?
Гамильтонов путь — это путь в графе, который проходит через каждую вершину ровно один раз. Он назван в честь Уильяма Роуэна Гамильтона, который изучал эту задачу на графе додекаэдра в 1857 году. Определение существования такого пути является NP-полной задачей, поэтому не существует известного алгоритма, решающего её за полиномиальное время для всех графов.
Чем гамильтонов цикл отличается от гамильтонова пути?
Гамильтонов цикл — это гамильтонов путь, который возвращается в исходную вершину, образуя замкнутую петлю, посещающую каждую вершину ровно один раз. Каждый гамильтонов цикл содержит гамильтонов путь (если убрать замыкающее ребро), но обратное неверно: многие графы имеют гамильтонов путь, но не имеют гамильтонова цикла.
О чем говорит теорема Дирака?
Теорема Дирака (1952) утверждает, что любой простой неориентированный граф с n ≥ 3 вершинами, в котором каждая вершина имеет степень не менее n/2, содержит гамильтонов цикл. Это достаточное, но не необходимое условие: многие графы, не проходящие порог Дирака, всё равно имеют гамильтоновы циклы.
О чем говорит теорема Оре?
Теорема Оре (1960) утверждает, что если для каждой пары несмежных вершин u и v в простом графе с n ≥ 3 вершинами сумма их степеней составляет не менее n, то граф имеет гамильтонов цикл. Условие Оре слабее условия Дирака, поэтому теорема Оре применима всегда, когда применима теорема Дирака.
Почему поиск ограничен 20 вершинами?
Задачи определения гамильтонова пути и цикла являются NP-полными. Время работы в худшем случае растет экспоненциально с числом вершин. Благодаря отсечению и эвристике Варнсдорфа калькулятор быстро обрабатывает многие небольшие графы до 20 вершин, но более сложные случаи могут привести к тайм-ауту. Для графов более 20 вершин следует использовать специализированные решатели, такие как Concorde, или формулировки целочисленного программирования.
Что такое эвристика Варнсдорфа?
Правило Варнсдорфа, предложенное в 1823 году для задачи о ходе коня, гласит, что на каждом шаге следует посещать ту следующую вершину, у которой меньше всего оставшихся непосещенных соседей. Это жадное правило на практике значительно сокращает дерево поиска с возвратом и часто находит гамильтоновы пути вообще без возвратов на регулярных графах.
Находит ли этот инструмент все гамильтоновы пути?
Нет — он находит один путь или цикл-свидетель, если они существуют. Подсчет общего количества гамильтоновых путей сам по себе является #P-полной задачей и гораздо сложнее задачи распознавания. Для перечисления лучше использовать специализированные инструменты или решатели целочисленного программирования.
Дополнительные материалы
- Гамильтонов путь — Википедия
- Задача о гамильтоновом пути — Википедия
- Теорема Дирака (англ.) — Википедия
- Теорема Оре — Википедия
- Правило Варнсдорфа — Википедия
Ссылайтесь на этот контент, страницу или инструмент так:
"Проверка Гамильтонова Пути" на сайте https://ru.miniWebtool.com/проверка-гамильтонова-пути/ от MiniWebtool, https://MiniWebtool.com/
командой miniwebtool. Обновлено: 21 апр. 2026 г.
Вы также можете попробовать наш AI Решатель Математических Задач GPT, чтобы решить ваши математические проблемы с помощью вопросов и ответов на естественном языке.
Другие сопутствующие инструменты:
Продвинутые математические операции:
- Антилогарифмический Калькулятор
- Калькулятор бета-функции
- Калькулятор биномиального коэффициента
- Калькулятор биномиального распределения
- Побитовый калькулятор
- Калькулятор центральной предельной теоремы
- Комбинированный калькулятор
- Калькулятор дополнительной функции ошибки
- Калькулятор комплексных чисел
- Калькулятор Энтропии
- Калькулятор функции ошибки
- Калькулятор экспоненциального распада
- Калькулятор экспоненциального роста: высокая точность
- Калькулятор экспоненциального интеграла
- калькулятор-показателей-высокая-точность
- Калькулятор факториала
- Калькулятор гамма-функции
- Калькулятор золотого сечения
- Калькулятор полураспада
- Калькулятор процентного роста
- Калькулятор перестановок
- Калькулятор распределения Пуассона
- Калькулятор корней многочленов с подробными шагами
- Калькулятор вероятности
- Калькулятор распределения вероятностей
- Калькулятор пропорций
- Калькулятор квадратичных формул
- Научный Калькулятор Рекомендуемое
- Калькулятор экспоненциальной записи
- Калькулятор значащих цифр Новый
- Калькулятор суммы кубов
- Калькулятор суммы последовательных чисел
- Калькулятор суммы квадратов
- Генератор таблицы истинности Новый
- Калькулятор теории множеств Новый
- Генератор диаграммы Венна (3 множества) Новый
- Калькулятор китайской теоремы об остатках Новый
- Калькулятор функции Эйлера Новый
- Калькулятор расширенного алгоритма Евклида Новый
- Калькулятор модулярного мультипликативного обратного Новый
- Калькулятор цепных дробей Новый
- Калькулятор кратчайшего пути Дейкстры Новый
- Калькулятор минимального остовного дерева Новый
- Валидатор последовательности степеней графа Новый
- Калькулятор беспорядков (субфакториал) Новый
- Калькулятор чисел Стирлинга Новый
- Калькулятор принципа голубятни Новый
- Калькулятор стационарного распределения цепи Маркова Новый
- Калькулятор округления Новый
- Калькулятор отрицательного биномиального распределения Новый
- Калькулятор перестановок с повторениями Новый
- Калькулятор Модульного Возведения в Степень Новый
- Калькулятор первообразного корня Новый
- Упроститель Булевой Алгебры Новый
- Решатель Карты Карно (K-Map) Новый
- Калькулятор раскраски графов Новый
- Калькулятор топологической сортировки Новый
- Калькулятор матрицы смежности Новый
- Калькулятор формулы включений-исключений Новый
- Решатель Линейного Программирования Новый
- Решатель задачи коммивояжёра (TSP) Новый
- Проверка Гамильтонова Пути Новый