티스토리 뷰

백준

백준 소스코드 [C++] 2630 색종이 만들기

Hani_Levenshtein 2020. 8. 19. 00:05

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

 

2630번: 색종이 만들기

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

www.acmicpc.net

백준 소스코드 [C++] 2630 색종이 만들기

#include <iostream>
#include <utility>
#include <vector>
#include <algorithm>
#include<cstring>
using namespace std;
int arr[129][129];
int white = 0, blue = 0;
void dfs(int s,int g, int out, int arr[][129]) {
	int sum = 0;
	for (int i = 1 + s;i <= s+out;i++)for (int j = 1 + g;j <= g+out;j++)
		if (arr[i][j] == 1) sum++;
	if (sum == out * out) {
		blue++; return;
	}
	else if (sum == 0) {
		white++; return;
	}
	else {
		for (int i = 0;i <= 1;i++)for (int j = 0;j <= 1;j++)
			dfs(s + i * out / 2, g + j * out / 2, out / 2, arr);
	}
}
int main() {
	int n;
	cin >> n;
	for (int i = 1;i <= n;i++)for (int j = 1;j <= n;j++) cin >> arr[i][j];
	dfs(0,0, n, arr);
	cout << white << '\n' << blue;
	return 0;
}
댓글