🔗 백준 4153 직각삼각형 https://www.acmicpc.net/problem/4153
문제

과거 이집트인들은 각 변들의 길이가 3, 4, 5인 삼각형이 직각 삼각형인것을 알아냈다. 주어진 세변의 길이로 삼각형이 직각인지 아닌지 구분하시오.
입력
입력은 여러개의 테스트케이스로 주어지며 마지막줄에는 0 0 0이 입력된다. 각 테스트케이스는 모두 30,000보다 작은 양의 정수로 주어지며, 각 입력은 변의 길이를 의미한다.
출력
각 입력에 대해 직각 삼각형이 맞다면 "right", 아니라면 "wrong"을 출력한다.
풀이
직각 삼각형은 z² = x² + y² 인데 이 문제에선 가장 긴 변이 입력받은 세개의 수 중 어떤 변인지 모른다.
그렇기에 나는 세개의 수가 각각 대각선인 조건을 3개를 만들었고 그 조건이 맞지 않는다면 "wrong", 아니면 "true"를 출력시켜줬다.
내가 푼 코드
더보기
import java.io.*;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
while (true) {
StringTokenizer st = new StringTokenizer(br.readLine());
double x = Integer.parseInt(st.nextToken());
double y = Integer.parseInt(st.nextToken());
double z = Integer.parseInt(st.nextToken());
if (x == 0 && y == 0 && z == 0) break;
if (Math.pow(x, 2) + Math.pow(y, 2) != Math.pow(z, 2)
&& Math.pow(y, 2) + Math.pow(z, 2) != Math.pow(x, 2)
&& Math.pow(z, 2) + Math.pow(x, 2) != Math.pow(y, 2)) {
System.out.println("wrong");
}
else System.out.println("right");
}
}
}
'Algorithm' 카테고리의 다른 글
[BaekJoon] 10845 큐 JAVA (0) | 2023.01.17 |
---|---|
[BaekJoon] 2231 분해합 JAVA (0) | 2023.01.17 |
[BaekJoon] 2798 블랙잭 JAVA (0) | 2023.01.17 |
[BaekJoon] 2108 통계학 JAVA (0) | 2023.01.17 |
[BaekJoon] 1978 소수 찾기 JAVA (0) | 2023.01.17 |