티스토리 뷰
[백준 2146번] 다리 만들기 URL
1. 각 섬마다 번호를 매긴다 (2, 3, 4, ....)
2. 그리고 모든 섬들을 큐에 넣어주고 BFS를 돌린다. BFS를 돌릴 때 다음 칸이 0이라는 뜻은 바다라는 뜻이므로
해당 섬의 번호로 땅을 확장한다.
3. 다음 칸이 0도 아니고, 현재 위치의 땅 번호와도 다르다면, 다른 땅이 그곳까지 확장됐다는 뜻이므로 거리를 계산한다.
4. 거리를 계산하는 방법은 dist라는 2차원 배열을 따로 만들고 BFS 탐색을 할 때 땅이 한 칸 확장되었다면 거리또한 1씩 증가시키는 것이다.
[소스 코드]
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 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 | import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.ArrayList; import java.util.Collections; import java.util.LinkedList; import java.util.List; import java.util.Queue; import java.util.StringTokenizer; public class Main { static int N, ans = Integer.MAX_VALUE; static int[][] map; static int[][] dist; static int[] dirX = new int[] { 0, 0, 1, -1 }; static int[] dirY = new int[] { 1, -1, 0, 0 }; static Queue<Node> q; static BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); static StringTokenizer st; public static void main(String[] args) throws IOException { st = new StringTokenizer(br.readLine()); N = Integer.parseInt(st.nextToken()); map = new int[N][N]; dist = new int[N][N]; q = new LinkedList<>(); for (int i = 0; i < N; i++) { st = new StringTokenizer(br.readLine()); for (int j = 0; j < N; j++) { map[i][j] = Integer.parseInt(st.nextToken()); } } int idx = 2; for (int i = 0; i < N; i++) { for (int j = 0; j < N; j++) { if (map[i][j] == 1) { setLand(i, j, idx++); } } } solve(); System.out.println(ans); } public static void solve() { while (!q.isEmpty()) { Node node = q.poll(); int row = node.row; int col = node.col; int land = node.land; for (int i = 0; i < 4; i++) { int nr = row + dirX[i]; int nc = col + dirY[i]; if (isBoundary(nr, nc)) { if (map[nr][nc] == 0) { map[nr][nc] = land; dist[nr][nc] = dist[row][col] + 1; q.offer(new Node(nr, nc, land)); } else if (map[nr][nc] != land && map[nr][nc] != 0) { ans = Math.min(ans, dist[nr][nc] + dist[row][col]); } } } } } public static void setLand(int row, int col, int land) { Queue<Node> temp = new LinkedList<>(); temp.offer(new Node(row, col, land)); while (!temp.isEmpty()) { Node node = temp.poll(); map[node.row][node.col] = land; q.offer(node); for (int i = 0; i < 4; i++) { int nr = node.row + dirX[i]; int nc = node.col + dirY[i]; if (isBoundary(nr, nc) && map[nr][nc] == 1) { map[nr][nc] = land; temp.offer(new Node(nr, nc, land)); } } } } public static boolean isBoundary(int row, int col) { return (row >= 0 && row < N) && (col >= 0 && col < N); } } class Node { int row; int col; int land; public Node(int row, int col, int land) { this.row = row; this.col = col; this.land = land; } } | cs |
'알고리즘 문제 > 백준(BOJ)' 카테고리의 다른 글
[백준 1976번] 여행가자 :: 늦깎이 IT (0) | 2019.03.25 |
---|---|
[백준 1717번] 집합의 표현 :: 늦깎이 IT (0) | 2019.03.25 |
[백준 2573번] 빙산 :: 늦깎이 IT (0) | 2019.03.23 |
[백준 2468번] 안전 영역 :: 늦깎이 IT (0) | 2019.03.23 |
[백준 9466번] 텀 프로젝트 :: 늦깎이 IT (0) | 2019.03.23 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
TAG
- 나무 재테크
- 14888
- 힙
- 우선순위 큐
- 탐색
- 구현
- 중간값
- DFS
- 브루트포스
- 최소힙
- 시뮬레이션
- 자바
- 영역 구하기
- 배열
- 큐
- 알고스팟
- BFS
- 트리
- SWEA
- 리스트
- 삼성
- 힙정렬
- 백준
- 탈주범 검거
- 최대힙
- 연산자 끼워넣기
- 알고리즘
- 구슬 탈출2
- 정렬
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함