Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 18.02.2022
Сообщений: 2

Определить, верно ли, что первый треугольник целиком содержится во втором

12.03.2022, 09:45. Показов 665. Ответов 1
Метки с++ (Все метки)

Студворк — интернет-сервис помощи студентам
Составить программу решения следующей задачи:
Даны действительные числа х1, у1, х2, у2, ..., х6, у6. Точки с координатами (х1, у1), (х2, у2), (х3, у3) рассматриваются как вершины первого треугольника, точки с координатами (х4, у4), (х5, у5), (х6, у6) - второго треугольника. Выяснить, верно ли, что первый треугольник целиком содержится во втором, и, если да, определить площадь области, принадлежащей внешнему треугольнику и не принадлежащей внутреннему. (Определить функцию, позволяющую выяснить, лежат ли две точки в одной полуплоскости относительно заданной прямой, функцию вычисления расстояния между двумя точками, а также функцию вычисления площади треугольника по трем сторонам.)

Я составил программу, но она не выводит результат. "верно ли, что первый треугольник целиком содержится во втором"/

https://pastebin.com/0i2LynsJ

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
#include <iostream>
#include <math.h>
using namespace std;
float coefk (float x1, float x2, float y1, float y2) {
    float k = ( y1 - y2 ) / (x1 - x2);
    return k;
}
float coefb(float x1, float x2, float y1, float y2) {
    float k = coefk (x1, x2, y1, y2);
    float b = y1 - k * x1;
    return b;
}
 
float dlin (float a1, float a2, float b1, float b2) {
    float r = sqrt ( (pow((a2 - a1), 2) + pow((b2 - b1), 2)));
    return r;
}
float plosh (float a, float b, float c) {
    float p =(a + b + c) / 2;
    float s=sqrt((p * (p - a) * (p - b) * (p - c)));
   return s;
    }
 
int main()
{
    setlocale(LC_ALL, "ru");
    float x1, x2, x3, x4, x5, x6, y1, y2, y3, y4, y5, y6;
    float k1=0, k2=0, k3=0, b1=0, b2=0, b3=0;
    cout << "\nx1 = "; cin >> x1;
    cout << "\ny1 = "; cin >> y1;
    cout << "\nx2 = "; cin >> x2;
    cout << "\ny2 = "; cin >> y2;
    cout << "\nx3 = "; cin >> x3;
    cout << "\ny3 = "; cin >> y3;
    cout << "\nx4 = "; cin >> x4;
    cout << "\ny4 = "; cin >> y4;
    cout << "\nx5 = "; cin >> x5;
    cout << "\ny5 = "; cin >> y5;
    cout << "\nx6 = "; cin >> x6;
    cout << "\ny6 = "; cin >> y6;
 
    int F = 0;
 
    if ((y4 == y5 && y6 > y4) || (y4 == y6 && y5 > y4) || (y5 == y6 && y4 > y5)) {
        F = 1;
    }
 
   
    int fl1 = 0;
    int fl2 = 0;
    int fl3 = 0;
    int fl = 0;
    if (F == 0) {
        if ((y4 == min(y4, y5)) && (y4 == min(y5, y6))) {
            k1 = coefk(x5, x6, y5, y6);
            b1 = coefb(x5, x6, y5, y6);
            k2 = coefb(x4, x6, y4, y6);
            b2 = coefb(x4, x6, y4, y6);
            k3 = coefb(x4, x5, y4, y5);
            b3 = coefb(x4, x5, y4, y5);
        }
 
        else if ((y5 == min(y4, y5)) && (y5 == min(y5, y6))) {
            k1 = coefk(x4, x6, y4, y6);
            b1 = coefb(x4, x6, y4, y6);
            k2 = coefk(x4, x5, y4, y5);
            b2 = coefb(x4, x5, y4, y5);
            k3 = coefk(x5, x6, y5, y6);
            b3 = coefb(x5, x6, y5, y6);
        }
        else if ((y6 == min(y4, y5)) && (y6 == min(y5, y6))) {
            k1 = coefk(x5, x4, y5, y4);
            b1 = coefb(x5, x4, y5, y4);
            k2 = coefk(x4, x6, y4, y6);
            b2 = coefb(x4, x6, y4, y6);
            k3 = coefk(x5, x6, y5, y6);
            b3 = coefb(x5, x6, y5, y6);
        }
    }
    else {
        if ((y4 == max(y4, y5)) && (y4 == max(y5, y6))) {
            k1 = coefk(x5, x6, y5, y6);
            b1 = coefb(x5, x6, y5, y6);
            k2 = coefk(x4, x6, y4, y6);
            b2 = coefb(x4, x6, y4, y6);
            k3 = coefk(x4, x5, y4, y5);
            b3 = coefb(x4, x5, y4, y5);
        }
 
        else if ((y5 == max(y4, y5)) && (y5 == max(y5, y6))) {
            k1 = coefk(x4, x6, y4, y6);
            b1 = coefb(x4, x6, y4, y6);
            k2 = coefk(x4, x5, y4, y5);
            b2 = coefb(x4, x5, y4, y5);
            k3 = coefk(x5, x6, y5, y6);
            b3 = coefb(x5, x6, y5, y6);
        }
        else if ((y6 == max(y4, y5)) && (y6 == max(y5, y6))) {
            k1 = coefk(x5, x4, y5, y4);
            b1 = coefb(x5, x4, y5, y4);
            k2 = coefk(x4, x6, y4, y6);
            b2 = coefb(x4, x6, y4, y6);
            k3 = coefk(x5, x6, y5, y6);
            b3 = coefb(x5, x6, y5, y6);
        }
    }
    if (F == 0) {
        if ((y1 < (k1 * x1 + b1)) && (y1 > (k2 * x1 + b2)) && (y1 > (k3 * x1 + b3))) {
            fl1 = 1;
        }
        if ((y2 < (k1 * x2 + b1)) && (y2 > (k2 * x2 + b2)) && (y2 > (k3 * x2 + b3))) {
            fl2 = 1;
        }
        if ((y3 < k1 * x3 + b1) && (y3 > k2 * x3 + b2) && (y3 > k3 * x3 + b3)) {
            fl3 = 1;
        }
        if ((fl1 == 1) && (fl2 == 1) && (fl3 == 1)) {
            fl = 1;
        }
    }
    else {
        if ((y1 > (k1 * x1 + b1)) && (y1 < (k2 * x1 + b2)) && (y1 < (k3 * x1 + b3))) {
            fl1 = 1;
        }
        if ((y2 > (k1 * x2 + b1)) && (y2 < (k2 * x2 + b2)) && (y2 < (k3 * x2 + b3))) {
            fl2 = 1;
        }
        if ((y3 > (k1 * x3 + b1)) && (y3 < (k2 * x3 + b2)) && (y3 < (k3 * x3 + b3))) {
            fl3 = 1;
        }
        if ((fl1 == 1) && (fl2 == 1) && (fl3 == 1)) {
            fl = 1;
        }
 
    }
 
    if (fl == 1) {
        float s1 = (plosh(dlin(x1, x2, y1, y2), dlin(x3, x2, y3, y2), dlin(x1, x3, y1, y3)));
        float s2 = (plosh(dlin(x4, x5, y4, y5), dlin(x4, x6, y4, y6), dlin(x5, x6, y5, y6)));
        float r = abs(s2 - s1);
        cout << "S=" << r;
        cout << "Первый треугольник целиком содержится во втором";
    }
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.03.2022, 09:45
Ответы с готовыми решениями:

Верно ли, что первый треугольник целиком содержится во втором
Выполнить задания двумя способами: с использованием инструкции if и с использованием условного оператора ?. Даны x1, x2, …x6, y1, y2,...

Задача на ветвления (С++) Выяснить, верно ли, что первый прямоугольник целиком содержится во втором
Даны x1, x2, …x6, y1, y2, … y6 – вещественные числа. Точки с координатами (x1, y1), (x2, y2), (x3, y3) рассматриваются как три вершины...

Функция проверяющая правильность того, что первый треугольник целиком содержится во втором
Не могу написать решение задачи. Помогите пожалуйста! Даны действительные числа x1, y1, x2, y2, ..., x6, y6. Точки с координатами (x1,...

1
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
12.03.2022, 18:14
Цитата Сообщение от x_vovaq_x Посмотреть сообщение
cout << "\nx1 = "; cin >> x1;
cout << "\ny1 = "; cin >> y1;
cout << "\nx2 = "; cin >> x2;
cout << "\ny2 = "; cin >> y2;
Жуть! А о существовании массивов вам известно?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.03.2022, 18:14
Помогаю со студенческими работами здесь

Выяснить, верно ли, что первый треугольник целиком содержится во втором
Даны действительные числа x1,y1,x2,y2,...,x6,y6.Точки с координатами (x1,y1), (x2,y2), (x3,y3) рассматриваются как вершины первого...

Определить, можно ли первый прямоугольник целиком разместить во втором
Два прямоугольника заданы длинами сторон. Определите, можно ли первый прямоугольник целиком разместить во втором.Решить в паскале

Определить, можно ли первый прямоугольник целиком разместить во втором
Два прямоугольника заданы длинами сторон. Стороны прямоугольников параллельны. Определить, можно ли первый прямоугольник целиком разместить...

Определить, можно ли первый заданный прямоугольник целиком разместить во втором
19. Два прямоугольника заданы длинами сторон. Стороны прямоугольников параллельны. Определить, можно ли первый прямоугольник целиком...

Выяснить, верно ли, что один треугольник целиком расположен внутри другого
Даны действительные числа x1, y1, x2, y2, ... , x6, y6 . Точки с координатами (x1, y1), (x2, y2), (x3, y3) рассматриваются как вершины ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru