[백준/Java] 4153번 문제 해설 및 답안

이재윤·2024년 1월 6일

백준

목록 보기
5/25

백준 4153번 자바 풀이

문제는 백준 사이트와 똑같으니, 해설부터 보셔도 됩니다.

문제

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

입력

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

출력

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

예제

입력
6 8 10
25 52 60
5 12 13
0 0 0

출력
right
wrong
right

해설

무한반복하는 while문에 세 변의 길이를 넣어줄 int 타입의 배열을 선언합니다.

배열의 크기만큼 반복하는 for문을 통해 변의 길이를 순차적으로 배열에 넣어주고, 세 변 중 가장 길이가 긴 변의 인덱스를 max라는 변수에 넣어줍니다.

이후, max가 2(세번째 인덱스)가 아니라면 max번째 변과 2번째 변을 바꿔줍니다. 세 변의 길이가 모두 0일 경우 while문을 종료합니다.

삼항 연산자를 통하여 조건(첫 번째 변의 길이 제곱 + 두 번째 변의 길이 제곱 = 세 번째 변의 길이 제곱)이 true일 경우 right, false일 경우 wrong을 s라는 문자열에 넣어주고 출력합니다.

  1. 무한반복하는 while문에 세 변의 길이를 넣어줄 int 타입의 배열을 선언.
  2. for문을 통해 변의 길이를 순차적으로 배열에 넣어주고, 세 변 중 가장 길이가 긴 변의 인덱스를 max라는 변수에 넣어줌.
  3. max가 2(세번째 인덱스)가 아니라면 max번째 변과 2번째 변을 바꿔줌. 세 변의 길이가 모두 0일 경우 while문을 종료.
  4. 삼항 연산자를 통하여 조건이 true => right, false => wrong을 s라는 문자열에 넣어주고 출력.

답안

import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		while(true) {
			int[] arr = new int[3];
			int max = 2;
			for (int i = 0; i < arr.length; i++) {
				arr[i] = sc.nextInt();
				if (arr[i] > arr[max]) max = i;
			}
			if (max != 2) {
				int temp = arr[2];
				arr[2] = arr[max];
				arr[max] = temp;
			}
			if (arr[0] == 0 && arr[1] == 0 && arr[2] == 0) break;
			String s = (Math.pow(arr[0], 2) + Math.pow(arr[1], 2) == Math.pow(arr[2], 2)) ? "right" : "wrong";
			System.out.println(s);
		}
	}

}
profile
부족한 점이 많습니다. 피드백은 환영입니다!

0개의 댓글