All Downloads are FREE. Search and download functionalities are using the official Maven repository.

g1001_1100.s1020_number_of_enclaves.Solution.kt Maven / Gradle / Ivy

package g1001_1100.s1020_number_of_enclaves

// #Medium #Array #Depth_First_Search #Breadth_First_Search #Matrix #Union_Find
// #Graph_Theory_I_Day_3_Matrix_Related_Problems
// #2024_05_02_Time_283_ms_(90.70%)_Space_57.5_MB_(65.12%)

class Solution {
    private fun walk(a: Array, visited: Array, x: Int, y: Int) {
        if (x >= a.size || x < 0 || y >= a[0].size || y < 0) {
            return
        }
        if (visited[x][y]) {
            return
        }
        if (a[x][y] == 0) {
            return
        }
        visited[x][y] = true
        walk(a, visited, x - 1, y)
        walk(a, visited, x, y - 1)
        walk(a, visited, x, y + 1)
        walk(a, visited, x + 1, y)
    }

    fun numEnclaves(a: Array): Int {
        val n = a.size
        val m = a[0].size
        val visited = Array(n) { BooleanArray(m) }
        for (i in 0 until n) {
            walk(a, visited, i, 0)
            walk(a, visited, i, m - 1)
        }
        for (j in 0 until m) {
            walk(a, visited, 0, j)
            walk(a, visited, n - 1, j)
        }
        var unreachables = 0
        for (i in 0 until n) {
            for (j in 0 until m) {
                if (a[i][j] == 1 && !visited[i][j]) {
                    ++unreachables
                }
            }
        }
        return unreachables
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy