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

g2101_2200.s2101_detonate_the_maximum_bombs.Solution.kt Maven / Gradle / Ivy

There is a newer version: 1.30
Show newest version
package g2101_2200.s2101_detonate_the_maximum_bombs

// #Medium #Array #Math #Depth_First_Search #Breadth_First_Search #Graph #Geometry
// #2023_06_25_Time_262_ms_(98.96%)_Space_40.7_MB_(78.76%)

class Solution {
    fun maximumDetonation(bombs: Array): Int {
        val n = bombs.size
        val graph: Array?> = arrayOfNulls(n)
        for (i in 0 until n) {
            graph[i] = ArrayList()
        }
        for (i in 0 until n) {
            for (j in i + 1 until n) {
                val dx = bombs[i][0] - bombs[j][0].toDouble()
                val dy = bombs[i][1] - bombs[j][1].toDouble()
                val r1 = bombs[i][2].toDouble()
                val r2 = bombs[j][2].toDouble()
                val dist = dx * dx + dy * dy
                if (dist <= r1 * r1) {
                    graph[i]?.add(j)
                }
                if (dist <= r2 * r2) {
                    graph[j]?.add(i)
                }
            }
        }
        val visited = BooleanArray(n)
        var ans = 0
        for (i in 0 until n) {
            ans = Math.max(ans, dfs(graph, i, visited))
            if (ans == n) {
                return ans
            }
            visited.fill(false)
        }
        return ans
    }

    private fun dfs(graph: Array?>, i: Int, visited: BooleanArray): Int {
        var cc = 0
        if (visited[i]) {
            return 0
        }
        visited[i] = true
        for (neigh in graph[i]!!) {
            cc += dfs(graph, neigh, visited)
        }
        return cc + 1
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy