개미의 개열시미 프로그래밍

[알고리즘] 백준2630 색종이만들기 - 자바 본문

알고리즘/DFS, BFS, 백트래킹

[알고리즘] 백준2630 색종이만들기 - 자바

YunHyeok 2022. 2. 17. 09:35
728x90
반응형

https://www.acmicpc.net/problem/2630

 

2630번: 색종이 만들기

첫째 줄에는 전체 종이의 한 변의 길이 N이 주어져 있다. N은 2, 4, 8, 16, 32, 64, 128 중 하나이다. 색종이의 각 가로줄의 정사각형칸들의 색이 윗줄부터 차례로 둘째 줄부터 마지막 줄까지 주어진다.

www.acmicpc.net

 

 

[풀이 코드]

package day0217;

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

public class BOJ_2630_색종이만들기 {
	static int N, wCnt, bCnt;
	static int[][] array;
	static int[] color = new int[2];
	
	public static void main(String[] args) throws IOException{
		// TODO Auto-generated method stub
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st;
		N = Integer.parseInt(br.readLine());
		
		array = new int[N][N];
		for(int i=0; i<N; i++) {
			st = new StringTokenizer(br.readLine());
			for(int j=0; j<N; j++) {
				array[i][j] = Integer.parseInt(st.nextToken());
			}
		}
		
		dfs(0, 0, N, N);
		for(int c : color) {
			System.out.println(c);
		}
	}
	
	static void dfs(int si, int sj, int ei, int ej) {
		boolean flag = true;
		int tmp = array[si][sj];
		for(int i=si; i<ei; i++) {
			for(int j=sj; j<ej; j++) {
				if(tmp != array[i][j]) flag = false; 
			}
		}
		if(flag) {
			color[tmp]++;
		}else {
			if(ei-si==1) {
				if(array[si][sj]==0) color[0]++;
				if(array[si][sj]==1) color[1]++;
				return;
			}
			
			int mi = (si+ei)/2;
			int mj = (sj+ej)/2;
			
			dfs(si, sj, mi, mj);
			dfs(si, mj, mi, ej);
			dfs(mi, sj, ei, mj);
			dfs(mi, mj, ei, ej);
		}
		
		
	}
}
  • 쿼드 트리를 풀었다면 쉽게 쉽게 풀 문제! 쿼드트리 코드랑 크게 다르지 않다~!
728x90
반응형
Comments