문제
1992번: 쿼드트리
첫째 줄에는 영상의 크기를 나타내는 숫자 N 이 주어진다. N 은 언제나 2의 제곱수로 주어지며, 1 ≤ N ≤ 64의 범위를 가진다. 두 번째 줄부터는 길이 N의 문자열이 N개 들어온다. 각 문자열은 0 또
www.acmicpc.net
풀이
분할정복을 활용해 풀이하면된다. 데이터를 네 부분으로 나누어 재귀적으로 탐색하는데, 탐색할 때마다 괄호를 열고 닫아주면 된다. 같은 데이터로 이루어진 부분을 찾으면 해당 숫자를 출력해준다.
코드
fun main() {
val br = System.`in`.bufferedReader()
val bw = System.out.bufferedWriter()
val size = br.readLine().toInt()
val arr = Array(size) { br.readLine().map { it - '0' }.toIntArray() }
fun checkData(size: Int, x: Int, y: Int): Boolean {
val first = arr[x][y]
for (i in x until x + size) {
for (j in y until y + size) {
if (arr[i][j] != first) return false
}
}
return true
}
fun divide(size: Int, x: Int, y: Int) {
if (size == 1 || checkData(size, x, y)) {
bw.append(if (arr[x][y] == 1) "1" else "0")
} else {
bw.append("(")
divide(size / 2, x, y)
divide(size / 2, x, y + size / 2)
divide(size / 2, x + size / 2, y)
divide(size / 2, x + size / 2, y + size / 2)
bw.append(")")
}
}
divide(size, 0, 0)
bw.write("")
bw.flush()
bw.close()
br.close()
}
'알고리즘 > Baekjoon' 카테고리의 다른 글
[백준] 1780번: 종이의 개수 - Kotlin[코틀린] (0) | 2024.02.27 |
---|---|
[백준] 9205번: 맥주 마시면서 걸어가기 - Kotlin[코틀린] (0) | 2024.02.26 |
[백준] 2630번: 색종이 만들기 - Kotlin[코틀린] (0) | 2024.02.05 |
[백준] 2503번: 숫자 야구 - Kotlin[코틀린] (0) | 2024.01.29 |
[백준] 11729번: 하노이 탑 이동 순서 - Kotlin[코틀린] (0) | 2024.01.25 |