[알고리즘] Java / 백준 / 직사각형과 쿼리 / 14846

정현명·2022년 3월 16일
0

baekjoon

목록 보기
97/180
post-thumbnail

[알고리즘] Java / 백준 / 직사각형과 쿼리 / 14846

문제


문제 링크



접근 방식


  1. 2차원 배열에 1부터 10까지 카운트 할 배열을 생성한다 ( 3차원 배열 )
  2. map[i][j][k] 는 i행 j열의 k 가 몇 개 누적되었는 지를 의미한다
  3. map[i][j][k] = map[i-1][j][k] + map[i][j-1][k] - map[i-1][j-1][k-1] 이다
  4. x1, y1 부터 x2, y2 까지 k의 누적 개수는 map[x2][y2][k] - map[x2][y1-1][k] - map[x1-1][y2][k] + map[x1-1][y1-1][k] 이다
  5. 모두 계산 후 각 숫자가 1개 이상인 만큼을 카운트한다


코드


import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class Main_14846 {

	static int N, Q;
	public static void main(String[] args) throws IOException{
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		N = Integer.parseInt(br.readLine());
		
		int[][][] map = new int[N+1][N+1][11];
		
		for(int i=1;i<=N;i++) {
			StringTokenizer st = new StringTokenizer(br.readLine());
			for(int j=1;j<=N;j++) {
				int num = Integer.parseInt(st.nextToken());
				for(int k=1;k<=10;k++) {
					map[i][j][k] = map[i-1][j][k] + map[i][j-1][k] - map[i-1][j-1][k];
				}
				map[i][j][num]++;
				
			}
		}
				
			
		
		StringBuilder sb = new StringBuilder();
		Q = Integer.parseInt(br.readLine());
		for(int i=0;i<Q;i++) {
			StringTokenizer st = new StringTokenizer(br.readLine());
			int x1 = Integer.parseInt(st.nextToken());
			int y1 = Integer.parseInt(st.nextToken());
			int x2 = Integer.parseInt(st.nextToken());
			int y2 = Integer.parseInt(st.nextToken());
			
			int temp[] = new int[11];
			
			int cnt = 0;
			for(int j=1;j<=10;j++) {
				temp[j] = map[x2][y2][j];
			}
			
			for(int j=1;j<=10;j++) {
				temp[j] = temp[j] - map[x2][y1-1][j] - map[x1-1][y2][j] + map[x1-1][y1-1][j];
			}
			
			for(int j=1;j<=10;j++) {
				if(temp[j] > 0) cnt++; 
			}
			
			sb.append(cnt+"\n");
		}
		
		System.out.print(sb);
	}

}

0개의 댓글