IT/알고리즘

[백준] 14502번 연구소

남갯 2024. 12. 16. 22:59
728x90
SMALL

 

 

https://www.acmicpc.net/problem/14502

 

1. 백트래킹으로 0,1의 dfs 탐색

2. 해당 그래프를 bfs로 탐색하며 2로 만들어 최대의 갯수를 구함

 

fun main() = with(Scanner(System.`in`)) {
    val n = nextInt()
    val m = nextInt()
    val graph = Array(n, { IntArray(m, { 0 }) })
    val copy_graph = Array(n, { IntArray(m, { 0 }) })
    val isVisited = Array(n, { Array(m, { false }) })

    var ans = 0

    for (i in 0 until n) {
        for (j in 0 until m) {
            graph[i][j] = nextInt()
        }
    }

    fun bfs() {
        val queue = LinkedList<Pair<Int, Int>>()
        val dx = mutableListOf<Int>(-1, 1, 0, 0)
        val dy = mutableListOf<Int>(0, 0, -1, 1)

        for (i in 0 until n) {
            for (j in 0 until m) {
                if (copy_graph[i][j] == 2) {
                    queue.add(Pair(i, j))
                    copy_graph[i][j] = 2
                    isVisited[i][j] = true
                }
            }
        }
        while (queue.isNotEmpty()) {
            val pos = queue.pop()
            for (i in 0 until 4) {
                val nx = pos.first + dx[i]
                val ny = pos.second + dy[i]
                if (nx < 0 || nx >= n || ny < 0 || ny >= m) continue
                if (copy_graph[nx][ny] == 0) {
                    queue.add(Pair(nx, ny))
                    copy_graph[nx][ny] = 2
                    isVisited[nx][ny] = true
                }
            }
        }
        var count = 0
        for(i in 0 until n){
            for(j in 0 until m){
                if(copy_graph[i][j] == 0){
                    count++
                }
            }
        }
        ans = max(ans , count)
    }
    fun wall(cnt: Int) {
        if (cnt == 3) {
            for (i in 0 until n) {
                for (j in 0 until m) {
                    isVisited[i][j] = false
                    copy_graph[i][j] = graph[i][j]
                }
            }
            bfs()
            return
        }

        for (i in 0 until n) {
            for (j in 0 until m) {
                if(graph[i][j] == 0){
                    graph[i][j] = 1
                    wall(cnt + 1)
                    graph[i][j] = 0
                }
            }
        }
    }
    wall(0)
    println(ans)
}
728x90
LIST