[백준] 1992번: 쿼드트리 - Kotlin[코틀린]

2024. 2. 6. 22:33·알고리즘/Baekjoon

문제

 

 

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
'알고리즘/Baekjoon' 카테고리의 다른 글
  • [백준] 1780번: 종이의 개수 - Kotlin[코틀린]
  • [백준] 9205번: 맥주 마시면서 걸어가기 - Kotlin[코틀린]
  • [백준] 2630번: 색종이 만들기 - Kotlin[코틀린]
  • [백준] 2503번: 숫자 야구 - Kotlin[코틀린]
junghoooooon
junghoooooon
  • junghoooooon
    코드팁스
    junghoooooon
  • 전체
    오늘
    어제
    • 전체 (120)
      • 안드로이드 (0)
        • 코드팁스 (0)
      • 유니티 (0)
        • 코드팁스 (0)
      • 알고리즘 (118)
        • 알고리즘 (0)
        • Baekjoon (118)
      • GitHub (0)
      • 티스토리 (2)
  • 블로그 메뉴

    • 링크

    • 공지사항

    • 인기 글

    • 태그

      BFS
      구현
      수학
      브루트포스
      피보나치
      누적 합
      크루스칼
      유니온파인드
      프림
      백트래킹
      그래프이론
      문자열
      스택
      DP
      분리집합
      그래프 탐색
      정렬
      소수 판정
      큐
      모듈러 곱셈 역원
      에라토스테네스의 체
      재귀
      이분 탐색
      티스토리
      분할 정복
      그리디
      우선순위 큐
      dfs
      MST
      투 포인터
    • hELLO· Designed By정상우.v4.10.2
    junghoooooon
    [백준] 1992번: 쿼드트리 - Kotlin[코틀린]
    상단으로

    티스토리툴바