티스토리 뷰

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

 

11123번: 양 한마리... 양 두마리...

문제 얼마전에 나는 불면증에 시달렸지... 천장이 뚫어져라 뜬 눈으로 밤을 지새우곤 했었지.  그러던 어느 날 내 친구 광민이에게 나의 불면증에 대해 말했더니 이렇게 말하더군. "양이라도 세�

www.acmicpc.net

백준 소스코드 [C++] 11123 양 한마리 양 두마리

#include <iostream>
#include <algorithm>
#include <queue>
#include <string.h>
using namespace std;
int  sum;
char arr[102][102];
bool check[102][102];
queue <pair<int, int>> q;
pair<int, int> pp, p[4] = {  {1,0},{-1,0},{0,1},{0,-1} };
void bfs() {
	while (q.empty() != true) {
		pp = q.front();
		q.pop();
		for (int i = 0;i < 4;i++) {
			if (arr[pp.first + p[i].first][pp.second + p[i].second] == '#'
				&& check[pp.first + p[i].first][pp.second + p[i].second] == true) {
				q.push(make_pair(pp.first + p[i].first, pp.second + p[i].second));
				check[pp.first + p[i].first][pp.second + p[i].second] = false;
			}
		}
	}
	sum++;
	return;
}
int main() {
	ios_base::sync_with_stdio(false);
	cin.tie(NULL);
	int t;
	int x = 1, y = 1;
	cin >> t;
	while(t--) {
		cin >> y >> x;
		sum = 0;
		for (int i = 0;i < 102;i++) {
			memset(arr[i], 0, sizeof(char) * 102);
			memset(check[i], true, sizeof(bool) * 102);
		}
		for (int j = 1;j <= y;j++)
			for (int i = 1;i <= x;i++) {
				cin >> arr[j][i];
			}

		for (int j = 1;j <= y;j++)
			for (int i = 1;i <= x;i++) {
				if (arr[j][i] == '#' && check[j][i] == true) {
					q.push(make_pair(j, i));
					check[j][i] = false;
					bfs();
				}
			}
		cout << sum << '\n';
	}
	return 0;
}
댓글