백준 30090 백신 개발 Kotlin

: ) YOUNG·2023년 9월 28일
1

알고리즘

목록 보기
263/417
post-thumbnail

백준 30090번
https://www.acmicpc.net/problem/30090

문제



생각하기


  • 백트래킹을 활용한 문자열 관리를 하는 문제이다.
    • 개인적으로 낮은 난이도에서 문자열과 백트래킹을 공부하기에 진짜 좋은 문제라고 생각함

동작



결과


코드


Kotlin

import java.io.*
import java.util.*

// input
private lateinit var br: BufferedReader

// variables
private const val INF = Int.MAX_VALUE / 16
private var N = 0
private lateinit var deque: Deque<String>

fun main() {
    br = BufferedReader(InputStreamReader(System.`in`))
    val bw = BufferedWriter(OutputStreamWriter(System.out))

    input()

    bw.write(solve())
    bw.close()
} // End of main()

private fun solve(): String {
    val sb = StringBuilder()

    sb.append(DFS("", 0))
    return sb.toString()
} // End of solve()

private fun DFS(current: String, depth: Int): Int {
    if (depth == N) {
        return current.length
    }

    var minLen = INF
    for (i in depth until N) {
        val temp = deque.pollFirst()
        val matchLen = check(current, temp)
        minLen = minLen.coerceAtMost(DFS(current + temp.substring(matchLen), depth + 1))
        deque.offerLast(temp)
    }

    return minLen
} // End of DFS()

private fun check(a: String, b: String): Int {
    val aLen = a.length
    val bLen = b.length

    val min = aLen.coerceAtMost(bLen)
    for (i in min downTo 1) {
        if (a.substring(aLen - i) == b.substring(0, i)) {
            // substring이 모두 일치하면 일치하는 최대 길이 return
            return i
        }
    }

    return 0
} // End of check()

private fun input() {
    N = br.readLine().toInt()
    deque = LinkedList()
    repeat(N) {
        deque.offer(br.readLine())
    }
} // End of input()

0개의 댓글