🌴 문제
문제
삼각형의 세 변의 길이가 주어질 때 변의 길이에 따라 다음과 같이 정의한다.
- Equilateral : 세 변의 길이가 모두 같은 경우
- Isosceles : 두 변의 길이만 같은 경우
- Scalene : 세 변의 길이가 모두 다른 경우
단 주어진 세 변의 길이가 삼각형의 조건을 만족하지 못하는 경우에는 "Invalid" 를 출력한다. 예를 들어 6, 3, 2가 이 경우에 해당한다. 가장 긴 변의 길이보다 나머지 두 변의 길이의 합이 길지 않으면 삼각형의 조건을 만족하지 못한다.
세 변의 길이가 주어질 때 위 정의에 따른 결과를 출력하시오.
입력
각 줄에는 1,000을 넘지 않는 양의 정수 3개가 입력된다. 마지막 줄은 0 0 0이며 이 줄은 계산하지 않는다.
출력
각 입력에 맞는 결과 (Equilateral, Isosceles, Scalene, Invalid) 를 출력하시오.
예제 입력 1 복사
7 7 7
6 5 4
3 2 5
6 2 6
0 0 0
예제 출력 1 복사
Equilateral
Scalene
Invalid
Isosceles
🌴 문제 분석
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.StringTokenizer;
public class day34 {
public static void main(String[] args) throws NumberFormatException, IOException {
//삼각형과 세 변
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int[] arr = new int[3];
// 무한루프
while(true) {
StringTokenizer st = new StringTokenizer(br.readLine());
arr[0] = Integer.parseInt(st.nextToken());
arr[1] = Integer.parseInt(st.nextToken());
arr[2] = Integer.parseInt(st.nextToken());
// 0 0 0 입력시 무한루프 종료
if(arr[0] == 0 && arr[1] == 0 && arr[2] == 0)
break;
// 정렬
Arrays.sort(arr);
if(arr[2] >= arr[0] + arr[1]) { // 가장 긴 변이 두 변의 합보다 크면
System.out.println("Invalid");
} else if (arr[0] == arr[1] && arr[1] == arr[2]) { // 세 변의 길이가 같으면
System.out.println("Equilateral");
} else if (arr[0] == arr[1] || arr[1] == arr[2] || arr[0] == arr[2]) { // 두 변의 길이가 같으면
System.out.println("Isosceles");
} else {
System.out.println("Scalene");
}
}
}
}
-----
7 7 7
Equilateral
6 5 4
Scalene
3 2 5
Invalid
6 2 6
Isosceles
0 0 0
'Algorithm' 카테고리의 다른 글
Algorithm - 삼각형 외우기 (Java) (0) | 2023.07.26 |
---|---|
Algorithm - 대지 (Java) (0) | 2023.07.12 |
Algorithm - 수학은 체육과목 입니다. (Java) (0) | 2023.07.10 |
Algorithm - 네 번째 점 (Java) (0) | 2023.07.07 |
Algorithm - 직사각형에서 탈출 (0) | 2023.07.06 |