-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTriangleSpace.cpp
68 lines (55 loc) · 2.52 KB
/
TriangleSpace.cpp
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
#include <iostream>
#include <conio.h>
#include <math.h>
#include <algorithm> // std::max
#include <cassert>
#include <limits.h> //std::numeric_limits
double TriangleSpace(const double a, const double b, const double c)
{
//1.1 Проверим корректность переданных параметров (строго больше 0)
if (a <= 0 || b <= 0 || c <= 0)
return 0;
//1.2 Проверим, что переданные параметры состовляют стороны прямоугольника по аксиоме:
//"Любая сторона треугольника меньше суммы двух других сторон и больше их разности"
if ((a > (b + c) || b > (a + c) || c > (a + b)) || (a < abs(b - c) || b < abs(a - c) || c < abs(a - b)))
return 0;
//2.1.Найдем максимальный параметр из переданных, это - гипотенуза, а остальные - катеты.
double max = std::max(std::max(a, b), c);
double katet1 = 0;
double katet2 = 0;
if (b < max && c < max) //если max = a
{
katet1 = b;
katet2 = c;
}
if (a < max && c < max) //если max = b
{
katet1 = a;
katet2 = c;
}
else //иначе max = c
{
katet1 = a;
katet2 = b;
}
//Проверка на ограниченние типа double (infinity) при дальнейших вычислениях
if (katet1*katet1 == std::numeric_limits<double>::infinity() || katet2*katet2 == std::numeric_limits<double>::infinity())
return 0;
//2.2 Теорема Пифагора. В прямоугольном треугольнике квадрат гипотенузы равен сумме квадратов катетов:
if (max*max == katet1*katet1 + katet2*katet2)
{
//треугольник прямоугольный, считаем площадь и возвращаем в результат
return (katet1 * katet2) / 2;
}
return 0;
}
int main()
{
assert(TriangleSpace(3, 4, 5) == 6); //прямоугольный треугольник
assert(TriangleSpace(3, 4, 6) == 0); //простой треугольник ( ноль, потому что он не прямоугольный)
assert(TriangleSpace(-3, 4, 8) == 0); //не треугольник
assert(TriangleSpace(std::numeric_limits<double>::max(), std::numeric_limits<double>::max() / 1.2, std::numeric_limits<double>::max() / 1.5) == 0); //очень большой треугольник
std::cout << "all test is completed!" << std::endl;
_getch();
return 0;
}