-
[백준/BOJ] 9063번 : 대지 (JAVA / 자바)백준 2022. 2. 8. 00:47
안녕하세요~ 코딩하는 코알못 코메인입니다.
https://www.acmicpc.net/problem/9063
- 문제 -
난이도 브론즈 3 문제이다.
자바에서 입력방식은 scanner와 bufferedreader가 있다.
자바를 초반에 접하면 처음에 배우는 입력은 scanner이다. scanner가 bufferedreader보다 편하지만 속도가 느리다.
bufferedreader는 무조건 문자열로 받아오기때문에 정수형이나 실수형 변수에 저장하기 위해서는 입력과 형변환을 해줘야한다.
더 자세한 내용은 아래 글 참고 하면 좋다.
풀이 방법
간단하게 생각해야한다. x좌표 제일 큰수에서 작은수를 빼고, y좌표 큰수에서 작은 수를 뺴면 가로 제일 긴 변이 나온다. 그 두 값을 곱하면 최소 크기의 사각형이 나온다.
A배열에 x값 저장, B 배열에 y값을 저장한다. 그리고 두 배열을 정렬하면 끝과 끝 인덱스가 최소 최대 값이 되기때문에 최대에서 최소를 빼준다.
-풀이-
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[] A = new int[N]; int[] B = new int[N]; for(int i = 0; i < N; i++) { StringTokenizer st = new StringTokenizer(br.readLine()); A[i] = Integer.parseInt(st.nextToken()); B[i] = Integer.parseInt(st.nextToken()); } //정렬 Arrays.sort(A); Arrays.sort(B); //정렬했기때문에 끝과 끝이 제일 큰수와 제일 작은 수가 된다. System.out.println((A[N - 1] - A[0]) * (B[N - 1] - B[0])); } }
-결과-
아직 코딩 공부가 부족한 필자라 설명과 풀이 방법이 많이 미흡할 수 있다. 코딩 고수분들은 보시고 문제점이 있다면 댓글로 말해주시면 감사한 마음으로 참고 수정 하겠습니다.
'백준' 카테고리의 다른 글
[백준/BOJ] 9085번 : 더하기 (JAVA / 자바) (0) 2022.02.08 [백준/BOJ] 8932번 : 7종 경기 (JAVA / 자바) (0) 2022.02.08 [백준/BOJ] 7789번 : 텔레프라임 (JAVA / 자바) (0) 2022.02.07 [백준/BOJ] 7770번 : 아즈텍 피라미드 (JAVA / 자바) (0) 2022.02.07 [백준/BOJ] 7510번 : 고급 수학 (JAVA / 자바) (0) 2022.02.07