일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 상한가
- 알고리즘
- 프로그래머스
- 상한가 분석
- 급등 이유
- 이진우
- 이진우의 손에 잡히는 경제
- 손에 잡히는 경제
- 백준
- 경제
- Programmers
- java
- 손경제
- 주식
- 주식 상한가
- 파이썬
- 코테
- 급등주
- 경제뉴스
- 상한가 이유
- 경제뉴스 요약
- 주식 분석
- 손에 잡히는 경제 요약
- 테마주
- 자바
- 손경제 요약
- 코딩테스트
- Python
- boj
- 급등주 분석
- Today
- Total
Completion over Perfection
백준 2667 - 단지번호붙이기 (JAVA 자바) 본문
백준 2667 - 단지번호붙이기 (JAVA 자바)
단순한 DFS 문제인줄 알았는데, 너무 어려웠어요.
예제코드는 잘 돌아가서 돌려봤는데 계속 실패가 떠서
댓글에 있는 반례를 가지고 코드 수정을 했습니다.
아래 사항에 주의하여 진행하셔야 합니다.
1. 지도는 숫자가 아닌 문자열로 들어옵니다. 문자열로 받아서 charAt 으로 잘라서 저장해야됩니다. (귀찮...)
2. 오름차순으로 출력을 해야합니다. Arrays.sort를 활용해서 오름차순으로 정리 후 출력하도록 합시다.
3. 단지가 1개인 경우에도 1개의 번호를 붙여야합니다.
특히 아래 예시의 경우, 313개의 단지가 나와야되며 1이 313번 출력되어야 합니다.
25
1010101010101010101010101
0101010101010101010101010
1010101010101010101010101
0101010101010101010101010
1010101010101010101010101
0101010101010101010101010
1010101010101010101010101
0101010101010101010101010
1010101010101010101010101
0101010101010101010101010
1010101010101010101010101
0101010101010101010101010
1010101010101010101010101
0101010101010101010101010
1010101010101010101010101
0101010101010101010101010
1010101010101010101010101
0101010101010101010101010
1010101010101010101010101
0101010101010101010101010
1010101010101010101010101
0101010101010101010101010
1010101010101010101010101
0101010101010101010101010
1010101010101010101010101
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.*;
public class Beakjoon_danzi {
static String n;
static int N, cnt, cnt2;
static char map[][];
static boolean visits[][];
static int dx[] = {-1,1,0,0};
static int dy[] = {0,0,-1,1};
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
n = br.readLine();
N = Integer.parseInt(n);
map = new char [N+2][N+2];
visits = new boolean [N+2][N+2];
for (int i=0; i<N; i++) {
String tmp = br.readLine();
for(int j=0; j<N; j++) {
map[i][j] = tmp.charAt(j);
}
}
cnt=0;
Queue <Integer> q = new LinkedList<Integer>();
for (int i=0; i<N; i++) {
for(int j=0; j<N; j++) {
if (map[i][j]=='1' && visits[i][j] == false) {
cnt2=0;
cnt++;
int result = dfs(i,j);
q.offer(result);
}
}
}
if (cnt == 0) {
System.out.println(cnt);
return;
}else {
System.out.println(cnt);
int list[] = new int [cnt];
while(!q.isEmpty()) {
for (int i=0; i<cnt; i++) {
int a = q.poll();
list[i] = a;
}
}
Arrays.sort(list);
for (int i=0; i<list.length; i++) {
System.out.println(list[i]);
}
}
}
private static int dfs(int x, int y) {
for(int i=0; i<4; i++) {
int new_x = x+dx[i];
int new_y = y+dy[i];
if (new_x<=N && new_y<=N && new_x>=0 && new_y>=0) {
if(visits[new_x][new_y]==false && map[new_x][new_y] == '1') {
visits[new_x][new_y] = true;
cnt2++;
dfs(new_x, new_y);
}
}
}
if (cnt2 == 0) {
cnt2++;
}
return cnt2;
}
}
|
cs |
'앨고리듬 알고리즘' 카테고리의 다른 글
백준 11724 - 연결 요소의 개수 (JAVA 자바) (0) | 2020.11.24 |
---|---|
백준 2606 - 바이러스 (JAVA 자바) (0) | 2020.11.23 |
백준 2798 - 블랙잭 (JAVA 자바) (0) | 2020.11.17 |
백준 9019 - DSLR (JAVA, 자바) (0) | 2020.11.14 |
백준 2178 - 미로탐색 (JAVA 자바) (0) | 2020.11.11 |