Помощь - Поиск - Пользователи - Календарь
Полная версия: Вектора в полуплоскости
Форум «Всё о Паскале» > Образование и наука > Математика
Fanat
Подскажите алгоритм (наверно, скорее формулу) определения находятся ли все (допустим 3) вектора в одной полуплоскости.
Например (1,1) (1,2) (-1,1) находятся, а (1,1), (-1,0), (1,-1) нет.
Fanat
Цитата(Fanat @ 20.12.2008 14:08) *

Подскажите алгоритм (наверно, скорее формулу) определения находятся ли все (допустим 3) вектора в одной полуплоскости.
Например (1,1) (1,2) (-1,1) находятся, а (1,1), (-1,0), (1,-1) нет.


В принципе уже сам придумал. Можно пройти по всем векторам, построить прямые ограничивающии полуплоскость, и если все остальные вектора лежат в ней или все не лежат то все вектора в одной полуплоскости.

Буду делать так. Может можно лучше.
Lapp
Цитата(Fanat @ 20.12.2008 14:08) *
алгоритм (наверно, скорее формулу) определения находятся ли все (допустим 3) вектора в одной полуплоскости.
Нет, скорее алгоритм smile.gif.
Идешь в цикле по всем векторам Ai.
Производишь поворот системы координат (от исходного положения) на угол, который текущий вектор Ai составляет с осью Х. После такого поворота его Y-компонента занулится:
(Aix, Aiy) -> (Aix', 0) .
Все остальные вектора также подвергнутся преобразованию:
(Ajx, Ajy) -> (Ajx', Ajy') .
Проходишь в цикле по всем остальным (кроме i-того и последнего) векторам и смотришь произведение:
mj = Ajy' * Aj+1y'
Если все такие произведения неотрицательны:
mj <=0 ,
то все вектора лежат в одной полуплоскости, причем сечение плоскости производится вектором Ai. Если нет - продолжить внешний цикл.

Вроде так. Замучился индексы проставлять.. smile.gif
Fanat
Цитата(Lapp @ 21.12.2008 9:57) *

Нет, скорее алгоритм smile.gif.
Идешь в цикле по всем векторам Ai.
Производишь поворот системы координат (от исходного положения) на угол, который текущий вектор Ai составляет с осью Х. После такого поворота его Y-компонента занулится:
(Aix, Aiy) -> (Aix', 0) .
Все остальные вектора также подвергнутся преобразованию:
(Ajx, Ajy) -> (Ajx', Ajy') .
Проходишь в цикле по всем остальным (кроме i-того и последнего) векторам и смотришь произведение:
mj = Ajy' * Aj+1y'
Если все такие произведения неотрицательны:
mj <=0 ,
то все вектора лежат в одной полуплоскости, причем сечение плоскости производится вектором Ai. Если нет - продолжить внешний цикл.

Вроде так. Замучился индексы проставлять.. smile.gif


Спасибо...думаю, пригодится smile.gif
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.