IT/알고리즘
[백준] 적록 색약
남갯
2024. 12. 4. 21:54
728x90
SMALL
queue에 넣으면서 4개의 경로방향으로 전부 탐색,
전체 경로를 훑으면서 안간곳을 탐색하며 전체 갯수를 구하는데, 모든 반례를 질문게시판에 찾으면서 테스트해도 실패..
fun main() = with(Scanner(System.`in`)) {
val size = nextInt()
val letterArray = Array(size) { CharArray(size) }
for (i in 0 until size) {
letterArray[i] = readln().toCharArray()
}
fun bfs(hasRGB: Boolean): Int {
val queue = LinkedList<Color>()
val isVisited = Array<Array<Boolean>>(size) { Array(size) { false } }
val action = arrayOf(Pair(1, 0), Pair(-1, 0), Pair(0, 1), Pair(0, -1))
var count = 0
for (i in 0 until size) {
for (j in 0 until size) {
if (isVisited[i][j]) {
continue
}
if (queue.isEmpty()) {
count++
isVisited[i][j] = true
queue.add(
Color(
x = i,
y = j,
letter = letterArray[i][j]
)
)
}
while (queue.isNotEmpty()) {
val color = queue.poll()
for (act in action) {
val resultX = color.x + act.first
val resultY = color.y + act.second
if (resultX < 0 || resultY < 0 || resultX >= size || resultY >= size || isVisited[resultX][resultY]) {
continue
}
if (letterArray[resultX][resultY] == color.letter ||
(hasRGB && ((letterArray[resultX][resultY] == 'R' && color.letter == 'G') || (letterArray[resultX][resultY] == 'G' && color.letter == 'R')))
) {
isVisited[resultX][resultY] = true
queue.add(
Color(
x = resultX,
y = resultY,
letter = letterArray[resultX][resultY]
)
)
}
}
}
}
}
return count
}
println(bfs(hasRGB = false))
println(bfs(hasRGB = true))
}
data class Color(val x: Int, val y: Int, val letter: Char)
아래는 테스트한 케이스들
// val size = 5
// val letterArray = arrayOf(
// arrayOf('R', 'R', 'R', 'B', 'B'),
// arrayOf('G', 'G', 'B', 'B', 'B'),
// arrayOf('B', 'B', 'B', 'R', 'R'),
// arrayOf('B', 'B', 'R', 'R', 'R'),
// arrayOf('R', 'R', 'R', 'R', 'R')
// )
// val size = 2
// val letterArray = arrayOf(
// arrayOf('G', 'R'),
// arrayOf('G', 'R'),
// )
// val size = 3
// val letterArray = arrayOf(
// arrayOf('R', 'R', 'G'),
// arrayOf('G', 'G', 'R'),
// arrayOf('G', 'G', 'R')
// )
// val size = 2
// val letterArray = arrayOf(
// arrayOf('R', 'G'),
// arrayOf('G', 'R')
// )
// val size = 5
// val letterArray = arrayOf(
// arrayOf('R', 'R', 'R', 'R', 'R'),
// arrayOf('R', 'B', 'B', 'B', 'R'),
// arrayOf('R', 'B', 'G', 'B', 'R'),
// arrayOf('R', 'B', 'B', 'B', 'R'),
// arrayOf('R', 'R', 'R', 'R', 'R')
// )
// val size = 3
// val letterArray = arrayOf(
// arrayOf('G', 'B', 'G'),
// arrayOf('G', 'B', 'G'),
// arrayOf('R', 'R', 'R')
// )
val size = 20
val letterArray = arrayOf(
"BBBBBRRRRRRRRRRRBBBB".toCharArray(),
"BBBBBRRRRRRRRRRRBBBB".toCharArray(),
"RBBBBBRRRRRRRRRRBBBB".toCharArray(),
"RRRBBBBRRRRRRRRRBBBB".toCharArray(),
"RRRBBBBRRRRRRRRRRBRB".toCharArray(),
"GRRBBBBRRRRRRRRRRBRR".toCharArray(),
"GGRRRRBBBRRRRRRRRBBB".toCharArray(),
"GGGRRRBBBRRRRRRRRBBB".toCharArray(),
"RRGGGGBBBRRRRRRRRBBB".toCharArray(),
"BBGGGGBBBBRRRRRRRBBB".toCharArray(),
"BBGGGGGBBBRRRRRRRBBB".toCharArray(),
"GBGGGGGBRRRRRRRRRBBB".toCharArray(),
"GGGGGGGGRRRRRRRRRBBB".toCharArray(),
"GGGGGGGGGRRRRRRRRBBB".toCharArray(),
"GGGGGGGGGGRRRRRRRBBB".toCharArray(),
"RRGGGGGGGGGGRRRRRRBB".toCharArray(),
"RRGGGGGGGGGGGGGGGRBB".toCharArray(),
"RRRGGGGGGGGGGGGGGRBB".toCharArray(),
"GGGGGGGBGGGGGGGGGGBB".toCharArray(),
"RRRRGGGGGGGGGGGGGGGG".toCharArray()
)
// val size = 5
// val letterArray = arrayOf(
// arrayOf('R', 'R', 'R', 'B', 'B'),
// arrayOf('G', 'R', 'B', 'B', 'B'),
// arrayOf('B', 'B', 'B', 'R', 'R'),
// arrayOf('B', 'B', 'R', 'R', 'R'),
// arrayOf('R', 'R', 'R', 'R', 'R')
// )
// val size = 5
// val letterArray = arrayOf(
// arrayOf('R', 'B', 'R', 'B', 'B'),
// arrayOf('R', 'R', 'B', 'G', 'G'),
// arrayOf('B', 'B', 'R', 'B', 'R'),
// arrayOf('R', 'R', 'R', 'B', 'B'),
// arrayOf('R', 'R', 'R', 'B', 'R')
// )
// val size = 3
// val letterArray = arrayOf(
// arrayOf('R', 'B', 'R'),
// arrayOf('B', 'B', 'B'),
// arrayOf('R', 'B', 'R'),
// )
728x90
LIST