반응형
플러드 필(Flood Fill)/시드 필(Seed Fill)
-다차원 배열의 어떤 칸과 연결된 영역을 찾는 알고리즘입니다.
-이 알고리즘은 그림 프로그램에서 연결된 비슷한 색을 가지는 영역에 '채우기' 도구에 사용되며, 바둑이나 지뢰찾기 같은 게임에서 어떤 비어있는 칸을 표시할지를 결정할 때에도 사용됩니다.
영역 색칠하기
1. 시작점이 원하는 색으로 칠해져있는지 확인합니다.
2. 시작점으로부터 4방향, 혹은 8방향 등으로 확장하여 주변 영역을 검색합니다.
3. 주변 영역이 원하는 색으로 칠해져있는지 확인합니다.
4. 주어진 영역을 모두 검색하며 위의 과정을 반복합니다.
백준 6186번: Best Grass(잡초 개수세기)
#include <iostream>
using namespace std;
int r, c; //r: 행, c: 열
char a[150][150]; //밭의 현재 잡초 현황
bool visit[150][150]; //밭의 검사 여부
int dx[4]={-1, 1, 0, 0}; //{왼쪽, 오른쪽, 아래, 위}
int dy[4]={0, 0, -1, 1}; //{왼쪽, 오른쪽, 아래, 위}
void dfs(int x, int y) { //dfs를 이용하여 주변 영역 탐색하기
visit[x][y]=true;
for(int i=0;i<4;i++) {
//i=0: (-1, 0)
//i=1: (1, 0)
//i=2: (0, -1)
//i=3: (0, 1)
int nx=x+dx[i];
int ny=y+dy[i];
if(nx<0||nx>=r||ny<0||ny>=c) continue; //0<nx<r, 0<ny<c 범위를 벗어나면 dfs를 마칩니다.
if(!visit[nx][ny]&&a[nx][ny]=='#') dfs(nx, ny); //아직 검사하지 않았고, 잡초가 존재하면 dfs를 통해 주변 영역을 검사합니다.
}
}
int main(void) {
int num=0;
cin>>r>>c;
for(int i=0;i<r;i++) {
for(int j=0;j<c;j++) {
cin>>a[i][j];
}
}
for(int i=0;i<r;i++) {
for(int j=0;j<c;j++) {
if(!visit[i][j]&&a[i][j]=='#') {
dfs(i, j); //아직 검사하지 않았고, 잡초가 존재하면 dfs를 통해 주변 영역을 검사합니다.
num++;
}
}
}
cout<<num<<endl;
return 0;
}
반응형