YJ/C++
[백준/BOJ/C++] 5073번 삼각형과 세 변
Team DAON
2021. 10. 27. 15:35
[문제]
삼각형의 세 변의 길이가 주어질 때 변의 길이에 따라 다음과 같이 정의한다.
- Equilateral : 세 변의 길이가 모두 같은 경우
- Isosceles : 두 변의 길이만 같은 경우
- Scalene : 세 변의 길이가 모두 다른 경우
단 주어진 세 변의 길이가 삼각형의 조건을 만족하지 못하는 경우에는 "Invalid" 를 출력한다. 예를 들어 6, 3, 2가 이 경우에 해당한다. 가장 긴 변의 길이보다 나머지 두 변의 길이의 합이 길지 않으면 삼각형의 조건을 만족하지 못한다.
세 변의 길이가 주어질 때 위 정의에 따른 결과를 출력하시오.
[입력]
각 줄에는 1,000을 넘지 않는 양의 정수 3개가 입력된다. 마지막 줄은 0 0 0이며 이 줄은 계산하지 않는다.
[출력]
각 입력에 맞는 결과 (Equilateral, Isosceles, Scalene, Invalid) 를 출력하시오.
[Source Code]
#include <stdio.h>
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
using namespace std;
int main() {
vector<int> vector;
while(true){
int a, b, c;
cin >> a >> b >> c;
if(a == 0 && b == 0 && c == 0) break;
else if((a+b) > c && (a+c) > b && (b + c) > a){
if(a == b && b == c)
vector.push_back(3);
else if( a != b && b != c && a != c)
vector.push_back(1);
else
vector.push_back(2);
}
else
vector.push_back(0);
}
for(int i = 0; i < vector.size(); i++){
if(vector[i] == 0) cout << "Invalid\n";
else if(vector[i] == 1) cout << "Scalene\n";
else if(vector[i] == 2) cout << "Isosceles\n";
else if(vector[i] == 3) cout << "Equilateral\n";
}
}
[결과 화면]