Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

МЕТОД ОБХОДА ГРЭХЕМА





 

Алгоритм со временем выполнения 0(N4) не позволит обрабатывать очень большие наборы данных. В этом разделе мы исследуем наш алгоритм с точки зрения наличия в нем ненужных вычислений.

Так ли необходимо проверять все треугольники, определяемые множеством из N точек, чтобы узнать, лежит ли некоторая точка в каком-либо из них? Если пет, то имеется некоторая надежда, что крайние точки можно найти за время, меньшее, чем О (N4). Грэхем в одной из первых работ, специально посвященных вопросу разработки эффективных геометрических алгоритмов [Graham (1972)], показал, что, выполнив предварительно сортировку точек, крайние точки можно найти за линейное время. Использованный им метод стал очень мощным средством в области вычислительной геометрии.

Предположим, что внутренняя точка уже найдена, а координаты других точек тривиальным образом преобразованы так, что найденная внутренняя точка оказалась в начале координат (для этого можно использовать полярную систему координат). Упорядочим N точек в соответствии со значениями полярного угла и расстояния от начала координат. Сравнение расстояний необходимо выполнять лишь в случае, если две точки имеют один и тот же полярный угол, но тогда они лежат на одной прямой с началом координат, и сравнение в этом случае тривиально.

Представив упорядоченные точки в виде дважды связанного кольцевого списка, получаем ситуацию, представленную на рис. 24. Обратите внимание: если точка не является вершиной выпуклой оболочки, то она является внутренней точкой для некоторого треугольника (O pq), где р и q— последовательные вершины выпуклой оболочки. Суть алгоритма Грэхема состоит в однократном просмотре упорядоченной последовательности точек, в процессе которого удаляются внутренние точки. Оставшиеся точки являются вершинами выпуклой оболочки, представленными в требуемом порядке.

Рис. 24. Начало обхода точек в методе Грэхема. Вершина р2 удаляется, если угол р1р2р3 оказывается вогнутым

 

Просмотр начинается с точки, помеченной как НАЧАЛО, в качестве которой можно взять самую правую с наименьшей ординатой точку из данного множества, заведомо являющуюся вершиной выпуклой оболочки. Тройки последовательных точек многократно проверяются в порядке обхода против часовой стрелки с целью определить, образуют или нет они угол, больший или равный л. Если внутренний угол р1р2р3 больше или равен л, то говорят, что р1р2р3, образуют «правый поворот», иначе они образуют «левый поворот». Из выпуклости многугольника непосредственно следует, что при его обходе будут делаться только левые повороты. Если р1р2р3 образуют правый поворот, то р2 не может быть крайней точкой, так как она является внутренней для треугольника (O р1р3 ). В зависимости от результата проверки угла, образуемого текущей тройкой точек, возможны два варианта продолжения просмотра:

1) р1р2р3 образуют правый поворот. Удалить вершину р2, и проверить тройку р0р2р3.

2) р1р2р3 образуют левый поворот. Продолжить просмотр, перейдя к проверке тройки р2р3р4.

Просмотр завершается, когда, обойдя все вершины, вновь приходим в вершину НАЧАЛО. Заметим, что вершина НАЧАЛО никогда не удаляется, так как она является крайней точкой, и поэтому при отходе назад после удаления точек, мы не сможем уйти дальше точки, предшествующей точке НАЧАЛО. Простой анализ показывает, что такой просмотр выполняется лишь за линейное время. Рассмотренный метод обхода границы многоугольника называется методом обхода Грэхема. Ниже дано более точное описание этого алгоритма

procedure ОБОЛОЧКА-ГРЭХЕМА(S)

1. Найти внутреннюю точку q.

2. Используя q как начало координат, упорядочить точки множества S лексикографически в соответствии с полярным углом и расстоянием от q. Организовать точки множества в виде кольцевого, дважды связанного списка со ссылками СЛЕД и ПРЕД и указателем НАЧАЛО на первую вершину. Значение true логической переменной f указывает на то, что вершина НАЧАЛО оказалась достигнутой при прямом продвижении по оболочке, а не в результате возврата.

3. Обход.

Begin

v:= НАЧАЛО; w:= ПРЕД[ v ]; f:= false;

while (СЛЕД[ v ] ¹ НАЧАЛО or f = false) do

Begin

if (СЛЕД[ v ]= w) then f:=true;

if (три точки: v, СЛЕД[ v ], СЛЕД[СЛЕД[ v ]] образуют левый поворот) then v:= СЛЕД[ v ] else

begin УДАЛИТЬ СЛЕД[ v ];

v:=ПРЕД[ v ]

End

End

End.

По окончании выполнения алгоритма список содержит упорядоченные нужным образом вершины оболочки.

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

Если вспомнить нижнюю оценку, обсуждавшуюся в разд. 1, то видно, что этот простой и изящный алгоритм имеет оптимальное время выполнения. Однако имеется одно обстоятельство, которое может вызвать некоторое беспокойство у читателя, — это использование полярных координат. В самом деле, это предполагает выполнение преобразования координат, что может быть затруднительным в системах с ограниченным набором примитивных операций. Кроме того, рассмотренный алгоритм является оптимальным в худшем случае, но мы, однако, не изучили его поведение в среднем. И ещё одно замечание заключается в том, что так как алгоритм основывается на теореме 3, применимой только в случае плоскости, алгоритм не имеет обобщения на случай пространств более высокой размерности. Поэтому имеет смысл рассмотреть какие-то другие методы решения проблемы, не обременённые вышеуказанными недостатками.







Дата добавления: 2015-09-04; просмотров: 1448. Нарушение авторских прав; Мы поможем в написании вашей работы!




Расчетные и графические задания Равновесный объем - это объем, определяемый равенством спроса и предложения...


Кардиналистский и ординалистский подходы Кардиналистский (количественный подход) к анализу полезности основан на представлении о возможности измерения различных благ в условных единицах полезности...


Обзор компонентов Multisim Компоненты – это основа любой схемы, это все элементы, из которых она состоит. Multisim оперирует с двумя категориями...


Композиция из абстрактных геометрических фигур Данная композиция состоит из линий, штриховки, абстрактных геометрических форм...

ТЕХНИКА ПОСЕВА, МЕТОДЫ ВЫДЕЛЕНИЯ ЧИСТЫХ КУЛЬТУР И КУЛЬТУРАЛЬНЫЕ СВОЙСТВА МИКРООРГАНИЗМОВ. ОПРЕДЕЛЕНИЕ КОЛИЧЕСТВА БАКТЕРИЙ Цель занятия. Освоить технику посева микроорганизмов на плотные и жидкие питательные среды и методы выделения чис­тых бактериальных культур. Ознакомить студентов с основными культуральными характеристиками микроорганизмов и методами определения...

САНИТАРНО-МИКРОБИОЛОГИЧЕСКОЕ ИССЛЕДОВАНИЕ ВОДЫ, ВОЗДУХА И ПОЧВЫ Цель занятия.Ознакомить студентов с основными методами и показателями...

Меры безопасности при обращении с оружием и боеприпасами 64. Получение (сдача) оружия и боеприпасов для проведения стрельб осуществляется в установленном порядке[1]. 65. Безопасность при проведении стрельб обеспечивается...

Признаки классификации безопасности Можно выделить следующие признаки классификации безопасности. 1. По признаку масштабности принято различать следующие относительно самостоятельные геополитические уровни и виды безопасности. 1.1. Международная безопасность (глобальная и...

Прием и регистрация больных Пути госпитализации больных в стационар могут быть различны. В цен­тральное приемное отделение больные могут быть доставлены: 1) машиной скорой медицинской помощи в случае возникновения остро­го или обострения хронического заболевания...

ПУНКЦИЯ И КАТЕТЕРИЗАЦИЯ ПОДКЛЮЧИЧНОЙ ВЕНЫ   Пункцию и катетеризацию подключичной вены обычно производит хирург или анестезиолог, иногда — специально обученный терапевт...

Studopedia.info - Студопедия - 2014-2025 год . (0.011 сек.) русская версия | украинская версия