-
[백준/BOJ] 7510번 : 고급 수학 (JAVA / 자바)백준 2022. 2. 7. 14:10
안녕하세요~ 코딩하는 코알못 코메인입니다.
https://www.acmicpc.net/problem/7510
- 문제 -
난이도 브론즈 3 문제이다.
자바에서 입력방식은 scanner와 bufferedreader가 있다.
자바를 초반에 접하면 처음에 배우는 입력은 scanner이다. scanner가 bufferedreader보다 편하지만 속도가 느리다.
bufferedreader는 무조건 문자열로 받아오기때문에 정수형이나 실수형 변수에 저장하기 위해서는 입력과 형변환을 해줘야한다.
더 자세한 내용은 아래 글 참고 하면 좋다.
풀이 방법
피타고라스의 정리를 이용 푼다.
세 입력값을 int형 배열에 저장한다. Arrays.sort를 이용해 작은 수부터 정렬을 해주고, 제일 큰수의 제곱곱과 다른 두 수의 제곱의 합이 같은지 확인하는 조건문을 만든다. 같다면 yes, 다르다면 no를 출력한다.
-풀이-
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.Arrays; import java.util.StringTokenizer; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); int n = Integer.parseInt(br.readLine()); int[] arr = new int[3]; for(int i = 1; i <= n; i++) { StringTokenizer st = new StringTokenizer(br.readLine()); arr[0] = Integer.parseInt(st.nextToken()); arr[1] = Integer.parseInt(st.nextToken()); arr[2] = Integer.parseInt(st.nextToken()); //조건과 상관없이 항상 출력되는 출력문 System.out.println("Scenario #" + i + ":"); //정렬 Arrays.sort(arr); if((arr[0] * arr[0]) + (arr[1] * arr[1]) == (arr[2] * arr[2])) { System.out.println("yes"); }else { System.out.println("no"); } //케이스 마다 사이에 빈줄을 출력 System.out.println(); } } }
-결과-
아직 코딩 공부가 부족한 필자라 설명과 풀이 방법이 많이 미흡할 수 있다. 코딩 고수분들은 보시고 문제점이 있다면 댓글로 말해주시면 감사한 마음으로 참고 수정 하겠습니다.
'백준' 카테고리의 다른 글
[백준/BOJ] 7789번 : 텔레프라임 (JAVA / 자바) (0) 2022.02.07 [백준/BOJ] 7770번 : 아즈텍 피라미드 (JAVA / 자바) (0) 2022.02.07 [백준/BOJ] 6609번 : 모기곱셈 (JAVA / 자바) (0) 2022.02.07 [백준/BOJ] 6378번 : 디지털 루트 (JAVA / 자바) (0) 2022.02.06 [백준/BOJ] 5692번 : 팩토리얼 진법 (JAVA / 자바) (0) 2022.02.06