티스토리 뷰

알고리즘/BOJ

[BOJ 2468] 안전 영역

히더 2018. 9. 18. 18:11

백준 :: BOJ :: 2468 :: 안전 영역


출처 : https://www.acmicpc.net/problem/2468


#include <iostream>

#include <memory.h>

#include <algorithm>

#include <queue>

using namespace std;


int N, maxH, cnt, ans;

int map[100][100];

bool visited[100][100];

int dir[4][2] = { {-1,0},{0,1},{1,0},{0,-1} };

queue <pair<int,int>> q;


inline bool check(int i, int j, int h) { return ((i>=0 && j>=0 && i<N && j<N 

&& !visited[i][j] && map[i][j]>h) ? true : false); }


void bfs(int i, int j, int h) {

visited[i][j] = true;

q.push(make_pair(i,j));

int ii, jj;


while (!q.empty()) {

ii = q.front().first; jj = q.front().second; q.pop();

for (int d = 0; d < 4; d++) {

int ni = ii + dir[d][0]; int nj = jj + dir[d][1];

if (check(ni, nj, h)) {

visited[ni][nj] = true;

q.push(make_pair(ni, nj));

}

}

}


}


int main() {

cin >> N; maxH = 0; ans = 1;

for (int i = 0; i < N; i++) {

for (int j = 0; j < N; j++) {

cin >> map[i][j];

maxH = max(maxH, map[i][j]);

}

}

for (int h = 1; h < maxH; h++) {

memset(visited, 0, sizeof(visited)); cnt = 0;

for (int i = 0; i < N; i++) {

for (int j = 0; j < N; j++) {

if (map[i][j]>h && !visited[i][j]) {

bfs(i, j, h); cnt++;

}

}

}

ans = max(ans, cnt);

}

cout << ans << endl;


return 0;

}


'알고리즘 > BOJ' 카테고리의 다른 글

[BOJ 7576] 토마토  (0) 2018.10.02
[BOJ 2178] 미로탐색  (0) 2018.10.02
[BOJ 2589] 보물섬  (0) 2018.09.18
[BOJ 2174] 로봇 시뮬레이션  (0) 2018.08.27
[BOJ 1103] 게임  (0) 2018.08.26
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함