Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 자바 문자열 예제
- 백준 1141
- 자바 이분 탐색 예제
- SQLD
- SQLD 요약
- 백준 동전1 자바
- SQLD 정리
- SQLD SQL 활용
- 백준 2512 자바
- 백준 접두사 자바
- SQLD SQL 최적화 기본 원리
- 백준 접두사 로직
- 백준 예산 코드
- SQLD 내용 정리
- 백준 2293 자바
- 너비우선탐색
- 백준 2293 동전 1
- 백준 부분합 로직
- SQLD 책
- 백준 예산 자바
- SQLD 내용
- 자바 DP 예제
- 백준 1141 로직
- 알고리즘
- 자바 예제
- SQL 기본 및 활용
- BFS
- 백준
- 백준 1141 접두사
- 오라클 예제
Archives
- Today
- Total
혼자 공부하는 공간
[JAVA] 백준 2667. 단지번호붙이기 (BFS) :: 로직/코드 - GODZ 본문
안녕하세요 GODZ입니다.
오늘은 BFS을 이용한 문제를 풀어볼 예정입니다.
1. 문제
2. 입출력 예제
3. 접근
-
단지의 탐색의 종료와 새 단지의 탐색의 시작 사이에 단지 수를 +1 합니다.
-
각 단지의 집 수를 오름차순으로 정렬해야하기 때문에 해당 정보를 위한 자료구조를 만듭니다.
-
2에서 나눈 단지 번호와 집의 수가 맵핑되지 않아도 되기 때문에 Map구조가 아닌 List나 배열을 사용하셔도 좋습니다. (저는 처음에 문제를 제대로 안읽어서 HashMap을 사용했습니다.)
4. 로직
-
2차원 배열을 순회하며 값이 1이고, 해당 좌표가 방문한 적이 없는 곳인 경우
-
단지 카운트를 증가, 방문 값을 true로 바꾸고 현재 좌표를 큐에 넣습니다.
-
큐 poll()로 값을 추출하고, 해당 단지의 집 갯수를 위해 집 카운트를 증가시킵니다.
-
인접 4방향의 좌표를 검사합니다. (dx, dy 배열 활용)
-
인접 좌표가 2차원 배열의 내부에 있고, 값이 1이고, 방문 값이 false인 경우
-
방문 값을 true로 바꾸고 인접 좌표를 큐에 넣습니다.
-
3번으로 가서 반복합니다.
-
한 단지에 대한 탐색이 끝나면(큐가 비어있을 때) 집 갯수를 0으로 초기화하고 1번으로 가서 반복합니다.
-
2차원 배열의 순회가 끝나면, 단지 값을 출력하고 각 단지에 대한 집 수를 오름차순으로 정렬한 후 출력합니다.
5. 코드
* 저는 단지를 key, 집 수를 value로 하는 HashMap을 통해 구현했습니다. 4의 로직과 약간의 차이가 있으니 감안하셔서 참고 부탁드립니다.
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.LinkedList;
import java.util.Map;
import java.util.StringTokenizer;
class Pos {
int nPos;
int mPos;
public Pos(int n, int m) {
this.nPos = n;
this.mPos = m;
}
}
public class Main {
static int N;
static int[] dirN = {-1, 1, 0, 0}; // 상,하,좌,우 순서
static int[] dirM = {0, 0, -1, 1}; // 상,하,좌,우 순서
static int[][] map;
static boolean[][] visited;
static LinkedList<Pos> queue;
static Map<Integer, Integer> res;
static int areaCnt;
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine().trim());
N = Integer.parseInt(st.nextToken());
map = new int[N][N];
visited = new boolean[N][N];
queue = new LinkedList<>();
res = new HashMap<Integer, Integer>();
areaCnt = 1;
for(int i = 0; i < N; i++) {
st = new StringTokenizer(br.readLine().trim());
String s = st.nextToken();
for(int j = 0; j < N; j++) {
map[i][j] = s.charAt(j) - '0';
}
}
solveBFS();
// System.out.println(res);
System.out.println(res.size());
ArrayList<Integer> keys = new ArrayList<>(res.keySet());
Collections.sort(keys, new Comparator<Integer>() {
@Override
public int compare(Integer o1, Integer o2) {
return res.get(o1) - res.get(o2);
}
});
for(int k : keys) {
System.out.println(res.get(k));
}
}
private static void solveBFS() {
for(int i = 0; i < N; i++) {
for(int j = 0; j < N; j++) {
Pos currPos = new Pos(i, j);
// i, j가 방문한 적이 없음 && 집인 좌표
if(boundaryCheck(currPos) && !visited[i][j]) {
// 새로운 구역이므로 areaCnt에 대한 map 생성
res.put(areaCnt, 0);
visited[i][j] = true;
queue.add(currPos);
while(!queue.isEmpty()) {
// 인접한 구간을 찾음, 구역 하나 씩 증가
res.put(areaCnt, res.get(areaCnt) + 1);
currPos = queue.poll();
for(int d = 0; d < 4; d++) {
Pos nextPos = new Pos(currPos.nPos + dirN[d], currPos.mPos + dirM[d]);
if(boundaryCheck(nextPos) && !visited[nextPos.nPos][nextPos.mPos]) {
queue.add(nextPos);
visited[nextPos.nPos][nextPos.mPos] = true;
}
}
}
// 더 이상 인접해있는 지점이 없음, 다음 영역으로
areaCnt++;
}
}
}
}
private static boolean boundaryCheck(Pos pos) {
boolean res = true;
if(pos.nPos < 0 || pos.mPos < 0 || pos.nPos >= N || pos.mPos >= N || map[pos.nPos][pos.mPos] == 0) {
res = false;
}
return res;
}
}
|
cs |
6. 결과
'알고리즘 > BFS' 카테고리의 다른 글
[JAVA] 백준 11724. 연결 요소의 개수(BFS) :: 로직/코드 - GODZ (0) | 2020.06.26 |
---|---|
[JAVA] 백준 1697. 숨바꼭질 (BFS) :: 로직/코드 - GODZ (0) | 2020.06.26 |
[JAVA] 백준 2178. 미로 탐색 (BFS) :: 로직/코드 - GODZ (0) | 2020.06.24 |
Comments