Кососимметрический графКососимметрический граф — ориентированный граф, изоморфный своему собственному транспонированному графу. Этот граф образуется путём обращения всех дуг с изоморфизмом и является инволюцией без неподвижных точек. Кососимметрические графы идентичны двойным покрытиям двунаправленных графов[англ.]. Кососимметрические графы введены сначала под именем антисимметричные орграфы Таттом[1], позднее под именем двойные накрывающие графы полярных графов их использовал Зелинка[2], а позже под именем графов двойных накрытий двунаправленных графов использовал Заславский[3]. Они возникают, например, в моделировании поиска чередующихся путей и циклов, в алгоритмах для поиска паросочетания в графах для тестирования, в задаче разложения конфигурации в игре «Жизнь» на меньшие компоненты, в задаче визуализации графов и в задаче построения графов вывода[англ.], используемых для эффективного решения задачи 2-выполнимости[англ.]. ОпределениеКак определяют, например, Голдберг и Карзанов[4], кососимметрический граф — это ориентированный граф вместе с функцией , отображающей вершины графа в другие его вершины и удовлетворяющей свойствам:
Можно использовать третье свойство для расширения до функции обращения ориентации дуг графа . Транспонированный граф графа является графом, образованным путём обращения каждого ребра графа , а определяет изоморфизм из в транспонированный граф. Однако для кососимметрического графа имеется дополнительное требование, заключающееся в том, чтобы изоморфизм переводил каждую вершину в другую вершину, не позволяя вершине отобразиться в саму себя, или группировать более двух вершин в цикле изоморфизма. Говорят, что путь или цикл в кососимметрическом графе регулярный, если для каждой вершины пути или цикла соответствующая вершина не является частью пути или цикла. ПримерыЛюбой ориентированный путь с чётным числом вершин кососимметричен согласно симметрии, которая обменивает два конца пути. Однако пути с нечётным числом вершин не являются кососимметрическими, поскольку симметрия обратной ориентации этого графа отображает среднюю вершину этого графа в себя, что не разрешено для кососимметрических графов. Аналогично, ориентированный цикл является кососимметрическим тогда и только тогда, когда он имеет чётное число вершин. В этом случае число различных отображений , которые реализуют косую симметрию графа, равно половине длины цикла. Полярные графы и путевые стрелки, графы двойного накрытия и двунаправленные графыКососимметрический граф можно эквивалентно определить как граф двойного накрытия полярного графа (их ввёл Зелинка[5][6], а Кук называл графами путевых стрелок[7][8]), которые являются неориентированными графами и в которых рёбра, смежные каждой вершине, разбиты на два подмножества. Каждая вершина полярного графа соответствует двум вершинам кососимметрического графа, и каждое ребро полярного графа соответствует двум рёбрам кососимметрического графа. Эту эквивалентность использовали Голдберг и Карзанов[4] для моделирования задач паросочетаний в терминах кососимметрических графов. В таком приложении два подмножества рёбер в каждой вершине являются входящими в паросочетание и не входящими в него рёбрами. Зелинка (согласно Ф. Зайтеку) и Кук визуализировали вершины полярного графа как точки, в которых сходятся несколько железнодорожных путей[англ.] — если поезд входит в путевую стрелку по железнодорожному пути, который приходит из одного направления, он должен выйти через путь в другом направлении. Задача поиска не самопересекающихся гладких кривых между заданными точками железнодорожного пути возникает при проверке, допустим ли некоторый вид визуализаций графов[9], и может быть промоделирована как поиск регулярного пути в кососимметрическом графе. Тесно связанным понятием является двунаправленный граф[англ.] Эдмондса и Джонсона[10] («поляризованный граф» в терминологии Зелинки[5][6]), граф, в котором каждая из двух вершин любого ребра может быть либо началом, либо концом, независимо от другой вершины. Двунаправленный граф можно интерпретировать как полярный граф, если разбить рёбра каждой вершины по виду ориентации ребра в этой вершине — начало или конец. Однако обмен ролей начал и концов в отдельной вершине («переключение» вершины в терминологии Заславского[3]) даёт другой двунаправленный граф, но тот же полярный граф. Изучены и другие взаимосвязи двунаправленных и кососимметрических графов[11][12]. Чтобы образовать граф двойного накрытия (то есть соответствующий кососимметрический граф) из полярного графа , создадим из каждой вершины графа две вершины, и , и пусть . Для каждого ребра графа создадим два ориентированных ребра в накрывающем графе, одна из в и одна из в . Если находится в первом подмножестве рёбер в , эти две дуги идут из в и из в , если же принадлежит другому подмножеству, дуги будут из в и из в . Обратно, если дан кососимметрический граф , можно образовать полярный граф, который имеет одну вершину для любой соответствующей пары вершин графа и одно неориентированное ребро для каждой соответствующей пары рёбер в . Неориентированные рёбра в каждой вершине полярного графа можно разбить на два подмножества согласно тому, из какой вершины исходного графа дуга выходит и в какую входит. Регулярный путь или цикл кососимметрического графа соответствует пути или циклу в полярном графе, который использует максимум одно ребро из каждого подмножества рёбер в каждой из его вершин. ПаросочетанияПри построении паросочетания в неориентированном графе важно найти чередующийся путь, путь через вершины, который начинается и кончается в не принадлежащих паросочетанию вершинах, и рёбра которого на нечётных позициях пути не принадлежат данному частичному паросочетанию, а рёбра на чётных позициях пути являются рёбрами паросочетания. Путём удаления из паросочетания рёбер из этого пути, принадлежащих паросочетанию, и добавления в него остальных рёбер пути, можно увеличить размер паросочетания. Аналогично, циклы, в которых чередуются рёбра из паросочетания и не из паросочетания, важны в задачах взвешенных паросочетаний. Как показали Голдберг и Карзанов[4], чередующийся путь или цикл в неориентированном графе может быть промоделирован как регулярный путь или цикл в кососимметрическом ориентированном графе. Для создания кососимметрического графа из неориентированного графа с имеющимся паросочетанием , рассмотрим граф как граф путевых стрелок, в котором рёбра в каждой вершине разбиты на принадлежащие сочетанию и не принадлежащие. Чередующийся путь в графе является тогда регулярным путём в этом графе путевых стрелок, а чередующийся цикл в графе является регулярным циклом в графе путевых стрелок. В 1996 году обобщены алгоритмы чередующихся путей и показано, что существование регулярного пути между любыми двумя вершинами кососимметрического графа может быть проверено за линейное время[4]. Если, кроме того, задана неотрицательная функция длины на рёбрах графа, которая назначает одинаковые длины ребру и ребру , кратчайший регулярный путь, соединяющий данную пару узлов в кососимметрическом графе с рёбрами и вершинами может быть найден за время . Если функция длины может принимать отрицательные значения, существование отрицательного регулярного цикла может быть проверено за полиномиальное время. Кроме задач с путями, возникающими при работе с паросочетаниями, изучались также кососимметрические обобщения теоремы о максимальном потоке и минимальном разрезе[1][13]. Теория игры «Жизнь»Кук[8] показал, что конфигурация в игре «Жизнь» может быть разбита на две меньшие конфигурации тогда и только тогда, когда граф ассоциированного графа путевых стрелок содержит регулярный цикл. Для графов путевых стрелок, содержащих не более трёх рёбер на одну вершину, это можно проверить за полиномиальное время путём удаления один за одним мостов (рёбер, удаление которых делает граф несвязным) и вершин, в которых все рёбра принадлежат одной части разбиения, пока есть возможность осуществлять такие упрощения. Если в результате получается пустой граф, регулярного цикла в графе нет. В противном случае регулярный цикл можно найти в любом компоненте, не содержащем мостов. Поиск мостов в этом алгоритме можно осуществить эффективно с помощью динамического алгоритма Сорупа[14]. Аналогичную технику удаления мостов в контексте паросочетаний рассматривали до этого Габов, Каплан и Тарьян[15]. Выполнимость![]() Задача 2-выполнимости[англ.], то есть выражение в конъюнктивной нормальной форме с двумя переменными или их отрицанием может быть преобразовано в граф вывода[англ.] путём замены каждого выражения двумя импликациями и . В этом графе каждая вершина олицетворяет переменную или её отрицание и каждое ориентированное ребро — импликацию. Граф по построению кососимметричен с функцией , которая отображает каждую переменную в её отрицание. В 1979 году установлено[16], что нахождение выполняющего набора значений для экземпляра задачи 2-выполнимости эквивалентно разбиению этого графа вывода на два подмножества вершин, и , так что никакая дуга не начинается в и кончается в . Если такое разбиение существует, выполняющий набор значений может быть получен путём назначения значения «Истина» каждой переменной из и значения «Ложь» каждой переменной из . Это можно сделать тогда и только тогда, когда никакая компонента сильной связности графа не содержит одновременно вершину и её дополняющую вершину . Если две вершины принадлежат одной и той же компоненте сильной связности, соответствующие переменные или их отрицания необходимым образом равны друг другу в любом выполняющем наборе значений экземпляра задачи 2-выполнимости. Полное время проверки сильной связности и нахождения разбиения графа вывода линейно от размера данного 2-CNF выражения. РаспознаваниеЗадача распознавания того, является ли данный ориентированный граф кососимметрическим, NP-полна. Это следует из результата 1981 года[17] о том, что NP-полна задача поиска обращающей цвета инволюции в двудольном графе, существующей тогда и только тогда, когда ориентированный граф, заданный ориентацией каждого ребра из одного класса цветов в другой, является кососимметрическим. Эта сложность не влияет на алгоритмы нахождения путей для кососимметрических графов, поскольку эти алгоритмы предполагают, что кососимметрическая структура задана как часть входных данных алгоритма, а не выводится только из графа. Примечания
Литература
|
Portal di Ensiklopedia Dunia