-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathProblema_1045.cpp
85 lines (70 loc) · 1.98 KB
/
Problema_1045.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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
/*
@autor: Victor E. B. Rodrigues;
@data: 23/06/2021;
@nome: Tipos de Triângulos;
*/
#include <bits/stdc++.h>
#include <cmath>
using namespace std;
int absAB(double& a, double& b){
if (a>b)
return a-b;
return (a-b) * (-1);
}
bool formaTriangulo(double& lado1, double& lado2, double& lado3){
if(lado1 < lado2 + lado3 && lado1 > absAB(lado2, lado3))
return true;
return false;
}
bool ehRetangulo(double& a, double& b, double& c){
return pow(a,2) == pow(b,2) + pow(c,2);
}
bool ehObtusangulo(double& a, double& b, double& c){
return pow(a,2) > pow(b,2) + pow(c,2);
}
bool ehAcutangulo(double& a, double& b, double& c){
return pow(a,2) < pow(b,2) + pow(c,2);
}
bool ehEquilatero(double& a, double& b, double& c){
return a == b && a == c;
}
bool ehIsosceles(double& a, double& b, double& c){
return a == b || a == c || b == c;
}
string getTipoTrianguloAngulo(double& a, double& b, double& c){
if(ehRetangulo(a,b,c))
return "Retangulo";
if(ehObtusangulo(a,b,c))
return "Obtusangulo";
if(ehAcutangulo(a,b,c))
return "Acutangulo";
}
string getTipoTrianguloLados(double& a, double& b, double& c){
if(ehEquilatero(a,b,c))
return "Equilatero";
if(ehIsosceles(a,b,c))
return "Isosceles";
return "";
}
int main() {
cin.tie(NULL);
cout.tie(NULL);
ios::sync_with_stdio(0);
double a, b, c;
cin >> a >> b >> c;
double arr[] = {a, b, c};
sort(arr, arr+3);
if(formaTriangulo(*(arr+2),*(arr+1),*arr)){
string tipoTrianguloAngulo = getTipoTrianguloAngulo(*(arr+2),*(arr+1),*arr);
transform(tipoTrianguloAngulo.begin(), tipoTrianguloAngulo.end(), tipoTrianguloAngulo.begin(), ::toupper);
cout<< "TRIANGULO " << tipoTrianguloAngulo<< endl;
string tipoTrianguloLados = getTipoTrianguloLados(*(arr+2),*(arr+1),*arr);
if (!tipoTrianguloLados.empty()){
transform(tipoTrianguloLados.begin(), tipoTrianguloLados.end(), tipoTrianguloLados.begin(), ::toupper);
cout << "TRIANGULO " << tipoTrianguloLados << endl;
}
}
else
cout << "NAO FORMA TRIANGULO" << endl;
return 0;
}