Skip to content

Commit 4e1e07e

Browse files
committed
[Silver II] Title: 섬의 개수, Time: 148 ms, Memory: 16252 KB -BaekjoonHub
1 parent ea5ba29 commit 4e1e07e

File tree

2 files changed

+123
-0
lines changed

2 files changed

+123
-0
lines changed
Lines changed: 38 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,38 @@
1+
# [Silver II] 섬의 개수 - 4963
2+
3+
[문제 링크](https://www.acmicpc.net/problem/4963)
4+
5+
### 성능 요약
6+
7+
메모리: 16252 KB, 시간: 148 ms
8+
9+
### 분류
10+
11+
그래프 이론, 그래프 탐색, 너비 우선 탐색, 깊이 우선 탐색
12+
13+
### 제출 일자
14+
15+
2024년 11월 13일 16:33:21
16+
17+
### 문제 설명
18+
19+
<p>정사각형으로 이루어져 있는 섬과 바다 지도가 주어진다. 섬의 개수를 세는 프로그램을 작성하시오.</p>
20+
21+
<p><img alt="" src="https://www.acmicpc.net/upload/images/island.png" style="width: 283px; height: 141px;"></p>
22+
23+
<p>한 정사각형과 가로, 세로 또는 대각선으로 연결되어 있는 사각형은 걸어갈 수 있는 사각형이다. </p>
24+
25+
<p>두 정사각형이 같은 섬에 있으려면, 한 정사각형에서 다른 정사각형으로 걸어서 갈 수 있는 경로가 있어야 한다. 지도는 바다로 둘러싸여 있으며, 지도 밖으로 나갈 수 없다.</p>
26+
27+
### 입력
28+
29+
<p>입력은 여러 개의 테스트 케이스로 이루어져 있다. 각 테스트 케이스의 첫째 줄에는 지도의 너비 w와 높이 h가 주어진다. w와 h는 50보다 작거나 같은 양의 정수이다.</p>
30+
31+
<p>둘째 줄부터 h개 줄에는 지도가 주어진다. 1은 땅, 0은 바다이다.</p>
32+
33+
<p>입력의 마지막 줄에는 0이 두 개 주어진다.</p>
34+
35+
### 출력
36+
37+
<p>각 테스트 케이스에 대해서, 섬의 개수를 출력한다.</p>
38+
Lines changed: 85 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,85 @@
1+
import java.io.BufferedReader;
2+
import java.io.InputStreamReader;
3+
import java.io.IOException;
4+
import java.util.Collection;
5+
import java.util.Collections;
6+
import java.util.LinkedList;
7+
import java.util.PriorityQueue;
8+
import java.util.Queue;
9+
import java.util.StringTokenizer;
10+
11+
public class Main {
12+
static int arr[][];
13+
static int dx[] = {-1,-1,-1,0,0,1,1,1};
14+
static int dy[] = {-1,0,1,-1,1,-1,1,0};
15+
static boolean[][] visited;
16+
static int w,h;
17+
18+
public static void main(String[] args) throws IOException {
19+
20+
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
21+
StringTokenizer st;
22+
23+
StringBuilder sb = new StringBuilder();
24+
while(true) {
25+
st = new StringTokenizer(br.readLine());
26+
w = Integer.parseInt(st.nextToken());
27+
h = Integer.parseInt(st.nextToken());
28+
29+
if(w==0 && h==0)
30+
break;
31+
32+
33+
arr = new int[h][w];
34+
visited = new boolean[h][w];
35+
36+
37+
for(int i =0; i<h; i++) {
38+
st = new StringTokenizer(br.readLine());
39+
for(int j =0; j<w; j++) {
40+
arr[i][j] = Integer.parseInt(st.nextToken());
41+
}
42+
}
43+
44+
int count =0;
45+
46+
for(int i =0; i<h; i++) {
47+
for(int j =0; j<w; j++) {
48+
if(visited[i][j] == false && arr[i][j]== 1) {
49+
bfs(i,j);
50+
count++;
51+
}
52+
}
53+
}
54+
sb.append(count).append("\n");
55+
}
56+
System.out.println(sb);
57+
58+
}
59+
static void bfs(int x, int y) {
60+
61+
Queue<int[]> queue = new LinkedList<>();
62+
63+
queue.add(new int[]{x,y});
64+
visited[x][y]= true;
65+
66+
while(!queue.isEmpty()) {
67+
int now[] = queue.poll();
68+
69+
int nowx = now[0];
70+
int nowy = now[1];
71+
72+
for(int i =0; i<8; i++) {
73+
int nx = nowx + dx[i];
74+
int ny = nowy + dy[i];
75+
if(nx >=0 && nx <h && ny >=0 && ny <w && arr[nx][ny] == 1) {
76+
if(visited[nx][ny] == false) {
77+
queue.add(new int[]{nx,ny});
78+
visited[nx][ny] =true;
79+
}
80+
}
81+
}
82+
}
83+
84+
}
85+
}

0 commit comments

Comments
 (0)