250x250
Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 막내의막무가내 코틀린 안드로이드
- 프로그래머스 알고리즘
- 막내의 막무가내
- 안드로이드 Sunflower 스터디
- 막내의막무가내 안드로이드 코틀린
- 막내의막무가내
- 2022년 6월 일상
- 주택가 잠실새내
- 부스트코스에이스
- flutter network call
- 막내의막무가내 프로그래밍
- 막내의막무가내 코볼 COBOL
- 프래그먼트
- 막내의막무가내 플러터
- 부스트코스
- 막내의막무가내 플러터 flutter
- 막내의막무가내 목표 및 회고
- 안드로이드 sunflower
- 막내의 막무가내 알고리즘
- 막무가내
- 안드로이드
- 막내의막무가내 rxjava
- 막내의막무가내 안드로이드 에러 해결
- 주엽역 생활맥주
- Fragment
- 막내의막무가내 SQL
- 막내의막무가내 일상
- 막내의막무가내 코틀린
- 막내의막무가내 알고리즘
- 막내의막무가내 안드로이드
Archives
- Today
- Total
막내의 막무가내 프로그래밍 & 일상
[알고리즘] 백준 14502 연구소 -dfs, bfs- 자바 코틀린 본문
728x90
백준 14502 연구소를 풀었습니다.
벽을 3개 세우고 바이러스를 퍼트리고 안전지역을 구하는 문제입니다.
다음과 같이 로직으로 풀었습니다.
1. 안전지역(0)에 모든 경우의 수로 벽을 3개 세운다 -백트랙킹-
2. 벽 3개를 세운 후 바이러스를 퍼트립니다. -bfs-
3. 안전구역의 최댓값을 구합니다.
문제를풀며 삽질했던 부분은 copy()가 깊은 복사가 안된다는 점입니다. 평소 1차원 배열은 깊은 복사가 되었던것같은데 2차원 배열에서는 안먹혀서 2중 반복문으로 새로 배열을 만들어주었습니다.
풀이는 다음과 같습니다.
[Java]
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;
public class Main {
private static int[][] map;
private static int[] dx = {-1, 0, 1, 0};
private static int[] dy = {0, -1, 0, 1};
private static int N;
private static int M;
private static ArrayList<Virus> virusList = new ArrayList<>();
private static int answer = 0;
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
N = sc.nextInt();
M = sc.nextInt();
map = new int[N + 2][M + 2];
for (int i = 0; i < map.length; i++) {
map[i][0] = 1;
map[i][M + 1] = 1;
}
for (int j = 0; j < map[0].length; j++) {
map[0][j] = 1;
map[N + 1][j] = 1;
}
for (int i = 1; i <= N; i++) {
for (int j = 1; j <= M; j++) {
map[i][j] = sc.nextInt();
if (map[i][j] == 2) {
virusList.add(new Virus(i, j));
}
}
}
dfs(0);
System.out.println(answer);
}
private static void dfs(int count) {
if (count == 3) {
// int[][] tmpMap = map.clone(); deep copy 안됨
int[][] tmpMap = new int[N + 2][M + 2];
for (int i = 0; i <= N + 1; i++) {
for (int j = 0; j <= M + 1; j++) {
tmpMap[i][j] = map[i][j];
}
}
for (Virus virus : virusList) {
spreadVirus(virus, tmpMap);
}
countSafeArea(tmpMap);
return;
}
for (int i = 1; i <= N; i++) {
for (int j = 1; j <= M; j++) {
if (map[i][j] == 0) {
map[i][j] = 1;
dfs(count + 1);
map[i][j] = 0;
}
}
}
}
private static void spreadVirus(Virus virus, int[][] map) {
Queue<Virus> queue = new LinkedList<>();
queue.offer(virus);
while (!queue.isEmpty()) {
Virus virus2 = queue.poll();
for (int i = 0; i < 4; i++) {
int x2 = virus2.x + dx[i];
int y2 = virus2.y + dy[i];
if (map[x2][y2] == 0) {
map[x2][y2] = 2;
queue.offer(new Virus(x2, y2));
}
}
}
}
private static void countSafeArea(int[][] map) {
int count = 0;
for (int i = 1; i <= N; i++) {
for (int j = 1; j <= M; j++) {
if (map[i][j] == 0) {
count++;
}
}
}
answer = Math.max(answer, count);
}
private static class Virus {
int x;
int y;
public Virus(int x, int y) {
this.x = x;
this.y = y;
}
}
}
[Kotlin]
import java.util.*
private lateinit var map: Array<IntArray>
private val dx = intArrayOf(-1, 0, 1, 0)
private val dy = intArrayOf(0, -1, 0, 1)
private var N = 0
private var M = 0
private val virusList = ArrayList<Virus>()
private var answer = 0
fun main(args: Array<String>) {
val sc = Scanner(System.`in`)
N = sc.nextInt()
M = sc.nextInt()
map = Array(N + 2) { IntArray(M + 2) }
for (i in map.indices) {
map[i][0] = 1
map[i][M + 1] = 1
}
for (j in map[0].indices) {
map[0][j] = 1
map[N + 1][j] = 1
}
for (i in 1..N) {
for (j in 1..M) {
map[i][j] = sc.nextInt()
if (map[i][j] == 2) {
virusList.add(Virus(i, j))
}
}
}
dfs(0)
println(answer)
}
private fun dfs(count: Int) {
if (count == 3) { // int[][] tmpMap = map.clone(); deep copy 안됨
val tmpMap = Array(N + 2) { IntArray(M + 2) }
for (i in 0..N + 1) {
for (j in 0..M + 1) {
tmpMap[i][j] = map[i][j]
}
}
for (virus in virusList) {
spreadVirus(virus, tmpMap)
}
countSafeArea(tmpMap)
return
}
for (i in 1..N) {
for (j in 1..M) {
if (map[i][j] == 0) {
map[i][j] = 1
dfs(count + 1)
map[i][j] = 0
}
}
}
}
private fun spreadVirus(virus: Virus, map: Array<IntArray>) {
val queue: Queue<Virus> = LinkedList()
queue.offer(virus)
while (!queue.isEmpty()) {
queue.poll().run {
for (i in 0..3) {
val x2 = x + dx[i]
val y2 = y + dy[i]
if (map[x2][y2] == 0) {
map[x2][y2] = 2
queue.offer(Virus(x2, y2))
}
}
}
}
}
private fun countSafeArea(map: Array<IntArray>) {
var count = 0
for (i in 1..N) {
for (j in 1..M) {
if (map[i][j] == 0) {
count++
}
}
}
answer = answer.coerceAtLeast(count)
}
data class Virus(var x: Int, var y: Int)
728x90
'알고리즘 > DFS, BFS, 시뮬, 백트래킹' 카테고리의 다른 글
[알고리즘] 백준 7562 나이트의 이동, 4693 섬의개수 -dfs, bfs- 자바 (0) | 2020.10.23 |
---|---|
[알고리즘] 백준 10026 적록색약 -dfs, bfs- 자바 (0) | 2020.10.22 |
[알고리즘] 프로그래머스 N으로 표현 -dfs - 자바 코틀린 (0) | 2020.10.09 |
[알고리즘] 백준 14889 스타트와 링크 -백트랙킹- 자바 코틀린 (0) | 2020.10.02 |
[알고리즘] 백준 14888 연산자 끼워넣기 -백트랙킹- 자바 코틀린 (0) | 2020.10.02 |
Comments