Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [Borland C++] Четырёхугольник, Проверить, является ли он выпуклым 
:(
    Опции темы
Forpost
Дата 7.10.2009, 18:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 11
Регистрация: 24.9.2007

Репутация: нет
Всего: нет



Здравствуйте, уважаемые программисты.
Подскажите пожалуйста, как решить задачу:
Четырехугольник ABCD задан координатами своих вершин на плоскости: : А(ха,уа), В(хb,уb), С(хс,ус), D(xd,yd). Проверить, является ли он выпуклым. Замечание. Есть несколько способов проверки выпуклости: анализ линейных неравенств, задаваемых сторонами; разбиение четырехугольника на треугольники со сравнением сумм их площадей и другие.

Заранее огромное спасибо.

Это сообщение отредактировал(а) Forpost - 7.10.2009, 18:45
PM MAIL   Вверх
t_gran
Дата 8.10.2009, 09:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 621
Регистрация: 13.11.2007
Где: г.Усть-Илимск

Репутация: 33
Всего: 37



Код

#include <iostream>

using namespace std;

struct TPoint
{
   int x, y;
};

//----------------------------------------------//
bool Intersection (TPoint start1, TPoint start2, TPoint end1, TPoint end2)
{
   TPoint dir1= {end1.x - start1.x, end1.y - start1.y};
   TPoint dir2= {end2.x - start2.x, end2.y - start2.y};

   //считаем уравнения прямых проходящих через отрезки
   float a1= -dir1.y;
   float b1= +dir1.x;
   float d1= -(a1*start1.x + b1*start1.y);

   float a2= -dir2.y;
   float b2= +dir2.x;
   float d2= -(a2*start2.x + b2*start2.y);

   //подставляем концы отрезков, для выяснения в каких полуплоскотях они
   float seg1_line2_start= a2*start1.x + b2*start1.y + d2;
   float seg1_line2_end= a2*end1.x + b2*end1.y + d2;

   float seg2_line1_start= a1*start2.x + b1*start2.y + d1;
   float seg2_line1_end= a1*end2.x + b1*end2.y + d1;

   //если концы одного отрезка имеют один знак, значит он в одной полуплоскости и пересечения нет.
   if (seg1_line2_start * seg1_line2_end >= 0 || seg2_line1_start * seg2_line1_end >= 0) 
      return false;

   return true;
}
//----------------------------------------------//
int main (int argc, char **argv)
{
   TPoint a= {1, 1};
   TPoint b= {5, 1};
   TPoint c= {5, 3};
   TPoint d= {1, 5};
   cout << (Intersection(a, b, c, d) ? "Выпуклый" : "Вогнутый") << endl;
   return 0;
}


Работает по принципу нахождения пересечения диагоналей. Функция взята отсюда.

Это сообщение отредактировал(а) t_gran - 8.10.2009, 10:28


--------------------
Я знаю, что ничего не знаю© Сократ
user posted image
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.1050 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.