728x90
문제 링크
문제 설명
평면에 네 개의 직사각형이 놓여 있는데 그 밑변은 모두 가로축에 평행하다. 이 네 개의 직사각형들은 서로 떨어져 있을 수도 있고, 겹쳐 있을 수도 있고, 하나가 다른 하나를 포함할 수도 있으며, 변이나 꼭짓점이 겹칠 수도 있다.
이 직사각형들이 차지하는 면적을 구하는 프로그램을 작성하시오.
입력
입력은 네 줄이며, 각 줄은 직사각형의 위치를 나타내는 네 개의 정수로 주어진다. 첫 번째와 두 번째의 정수는 사각형의 왼쪽 아래 꼭짓점의 x좌표, y좌표이고 세 번째와 네 번째의 정수는 사각형의 오른쪽 위 꼭짓점의 x좌표, y좌표이다. 모든 x좌표와 y좌표는 1이상이고 100이하인 정수이다.
출력
첫 줄에 네개의 직사각형이 차지하는 면적을 출력한다.
구조화
전체를 boolean map으로 만들어서, 들어오는 직사각형 체크하며 면적++
이미 true이면 ++안함
오답 노트
입력 순서 잘못함
소스 코드
import java.io.*;
import java.util.*;
public class Main {
public static void main(String[] args) throws IOException {
int ans = 0;
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
boolean[][] map = new boolean[101][101];
for (int i = 0; i < 4; i++) {
StringTokenizer st = new StringTokenizer(br.readLine());
int sx = Integer.parseInt(st.nextToken());
int sy = Integer.parseInt(st.nextToken());
int ex = Integer.parseInt(st.nextToken());
int ey = Integer.parseInt(st.nextToken());
for (int j = sx; j < ex; j++) {
for (int k = sy; k < ey; k++) {
if (!map[j][k]) {
map[j][k] = true;
ans++;
}
}
}
}
System.out.println(ans);
}
}
'Algorithm > 백준' 카테고리의 다른 글
BOJ 5635 생일 🥳 (1) | 2024.04.19 |
---|---|
BOJ 2491 수열 📈📉 (0) | 2024.04.15 |
BOJ 28278 스택 2 🗑 (0) | 2024.04.12 |
BOJ 1205 등수 구하기(JAVA) 🥇 (0) | 2024.04.11 |
BOJ 14400 편의점 2(JAVA) 🏪 (1) | 2023.12.29 |