Эксцентриситет вершины - это длина самого длинного кратчайшего пути, начиная с . Диаметр - это максимальный эксцентриситет по всем вершинам. Любая BFS из вершины установит ее эксцентриситет. Поэтому ключевой идеей эффективного нахождения диаметра является предварительная обработка графа для нахождения небольшого набора вершин, по крайней мере одна из которых достигает максимальной эксцентриситета.vv
Выполняя лексикографический поиск в ширину , конечная вершина часто имеет высокий эксцентриситет. В частности, он гарантированно имеет эксцентриситет не более чем на один диаметр меньше для хордовых графов. Для некоторых подклассов хордовых графов, таких как интервальные графы , гарантируется максимальный эксцентриситет. Это также справедливо для некоторых нехордальных классов, таких как -безопасные графы.{AT,claw}
LBFS и BFS являются линейными по размеру графика, но, конечно, если (например, ), тогда время выполнения не будет . Ваше обсуждение подразумевает, что вы, вероятно, действительно хотите линейный алгоритм а не .m=Ω(n2)Kno(n2)O(m+n)o(n2)
Поэтому для некоторых подклассов хордовых графов линейный алгоритм состоит в том, чтобы запустить LBFS, взять конечную вершину, а затем запустить BFS, начиная с этой вершины. Для хордовых графов это определит диаметр с погрешностью не более 1. Графики, для которых это точно, кажутся теми, где четные степени являются хордальными. Это именно те хордальные графы, которые не содержат восходящего солнца или подграфа, сохраняющего расстояния.(rising sun−K2)
(источник: graphclasses.org )
- Федор Ф. Драган, Фальк Николай и Андреас Брандштадт , LexBFS-упорядочения и степени графов , WG 1996, LNCS 1197, 166–180. doi: 10.1007 / 3-540-62559-3_15
Я не знаю, можно ли это расширить, чтобы точно рассчитать диаметр для всех хордовых графов. Исследование Корнейла, кажется, показывает, что это все еще было открыто в 2004 году. Я также не знаю, был ли проведен анализ по расширению поиска от одной вершины до небольшого постоянного числа или начальных вершин; это может быть интересно исследовать.logn