백준 알고리즘
[Bronze III] 삼각형과 세 변 - 5073
성능 요약
메모리: 13152 KB, 시간: 4 ms
분류
수학, 구현, 기하학
문제 설명
삼각형의 세 변의 길이가 주어질 때 변의 길이에 따라 다음과 같이 정의한다.
- Equilateral : 세 변의 길이가 모두 같은 경우
- Isosceles : 두 변의 길이만 같은 경우
- Scalene : 세 변의 길이가 모두 다른 경우
단 주어진 세 변의 길이가 삼각형의 조건을 만족하지 못하는 경우에는 "Invalid" 를 출력한다. 예를 들어 6, 3, 2가 이 경우에 해당한다. 가장 긴 변의 길이보다 나머지 두 변의 길이의 합이 길지 않으면 삼각형의 조건을 만족하지 못한다.
세 변의 길이가 주어질 때 위 정의에 따른 결과를 출력하시오.
입력
각 줄에는 1,000을 넘지 않는 양의 정수 3개가 입력된다. 마지막 줄은 0 0 0이며 이 줄은 계산하지 않는다.
출력
각 입력에 맞는 결과 (Equilateral, Isosceles, Scalene, Invalid) 를 출력하시오.
Code
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
use std::io::{self, BufRead};
fn main() {
let stdin = io::stdin();
loop {
let mut input = String::new();
stdin.lock().read_line(&mut input).unwrap();
let nums: Vec<i32> = input
.split_whitespace()
.map(|x| x.parse().unwrap())
.collect();
let a = nums[0];
let b = nums[1];
let c = nums[2];
if a == 0 && b == 0 && c == 0 {
break;
}
if a == b && b == c {
println!("Equilateral");
} else if a >= b + c || b >= c + a || c >= a + b {
println!("Invalid");
} else if a == b || b == c || c == a {
println!("Isosceles");
} else {
println!("Scalene");
}
}
}