Как отсортировать векторы по полярному углу для алгоритма Грэхема? Подскажите пожалуйста где можно найти описание алгоритма на псевдокоде

21 Авг 2019 в 06:16
195 +1
0
Ответы
1

Чтобы отсортировать векторы по полярному углу для алгоритма Грэхема, можно воспользоваться следующим подходом:

Выбрать начальную точку (обычно это точка с самой маленькой координатой y и, если таких точек несколько, то с самой маленькой координатой x).Вычислить полярный угол каждой точки относительно выбранной начальной точки.Отсортировать точки по возрастанию полярного угла.Если есть точки с одинаковым полярным углом, оставить только точку с наибольшим расстоянием от начальной точки.Теперь точки будут отсортированы по полярному углу.

Что касается описания алгоритма Грэхема на псевдокоде, его можно найти во многих источниках, таких как учебники по вычислительной геометрии, алгоритмическим справочникам и онлайн-курсах по алгоритмам. Например, вот пример псевдокода алгоритма Грэхема для построения выпуклой оболочки:

GrahamScan(points):
sort points by polar angle
stack = []
for each point in points:
while size(stack) >= 2 and orientation(next_to_top(stack), top(stack), point) is not counterclockwise:
stack.pop()
stack.push(point)
return stack

Этот псевдокод демонстрирует основные шаги алгоритма Грэхема: сортировку точек по полярному углу и построение выпуклой оболочки с использованием стека.

20 Апр в 13:21
Не можешь разобраться в этой теме?
Обратись за помощью к экспертам
Название заказа не должно быть пустым
Введите email
Бесплатные доработки
Гарантированные бесплатные доработки
Быстрое выполнение
Быстрое выполнение от 2 часов
Проверка работы
Проверка работы на плагиат
Интересные статьи из справочника
Поможем написать учебную работу
Название заказа не должно быть пустым
Введите email
Доверьте свою работу экспертам
Разместите заказ
Наша система отправит ваш заказ на оценку 92 436 авторам
Первые отклики появятся уже в течение 10 минут
Прямой эфир