Home [BaekJoon] 4153 직각삼각형 JAVA
Post
Cancel

[BaekJoon] 4153 직각삼각형 JAVA

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

**문제 **

img

과거 이집트인들은 각 변들의 길이가 3, 4, 5인 삼각형이 직각 삼각형인것을 알아냈다. 주어진 세변의 길이로 삼각형이 직각인지 아닌지 구분하시오.


입력

입력은 여러개의 테스트케이스로 주어지며 마지막줄에는 0 0 0이 입력된다. 각 테스트케이스는 모두 30,000보다 작은 양의 정수로 주어지며, 각 입력은 변의 길이를 의미한다.


출력

각 입력에 대해 직각 삼각형이 맞다면 “right”, 아니라면 “wrong”을 출력한다.


풀이

직각 삼각형은 z² = x² + y² 인데 이 문제에선 가장 긴 변이 입력받은 세개의 수 중 어떤 변인지 모른다.

그렇기에 나는 세개의 수가 각각 대각선인 조건을 3개를 만들었고 그 조건이 맞지 않는다면 “wrong”, 아니면 “true”를 출력시켜줬다.

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
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");
        }
    }
}
This post is licensed under CC BY 4.0 by the author.