알고리즘 문제 풀이/프로그래머스

[Algorithm] 프로그래머스 - 그림 확대 (Kotlin)

참깨빵위에참깨빵 2024. 7. 4. 19:07
728x90
반응형
직사각형 형태의 그림 파일이 있고 이 파일은 1x1 크기의 정사각형 픽셀로 이뤄져 있다. 이 파일을 나타낸 문자열 배열 picture, 정수 k가 매개변수로 주어질 때, 이 파일을 가로와 세로로 k배 늘린 파일을 나타내도록 문자열 배열을 리턴하는 함수를 완성하라

 

 

풀이법이 떠오르지 않아서 챗지피티에 확인해 봤다.

 

class Solution {
    fun solution(picture: Array<String>, k: Int): Array<String> {
        val result = mutableListOf<String>()

        for (row in picture) {
            val expandedRow = row.flatMap { char -> List(k) { char } }.joinToString("")
            repeat(k) {
                result.add(expandedRow)
            }
        }

        return result.toTypedArray()
    }
}

 

flatMap은 리스트 안의 요소들을 다른 리스트로 매핑한 다음 모든 리스트를 하나로 평평하게 만드는 함수다.

List(k) { char }는 k개의 char를 가진 리스트를 생성한다.

때문에 expandedRow에는 행의 각 문자를 k번 반복해서 새 리스트를 생성한 후 하나로 만든다.

아래는 예시 코드다.

 

fun main() {
    val row = "x.x"
    val k = 3

    // 각 문자를 k번 반복하는 리스트로 변환한 후 평평하게 만든 리스트
    val expandedRow = row.flatMap { char -> List(k) { char } }.joinToString("")
    println(expandedRow) // "xxx...xxx"
}

 

char가 x고 k가 3이면 List(3) { char }는 ['x', 'x', 'x']를 생성한다.

점과 나머지 x에도 동일한 처리가 가해지면 "xxx...xxx"를 출력하는 것이다.

마지막에 joinToString("")을 써서 중간 공백이 없는 문자열로 만드는데, 이 작업을 solution()의 2번째 매개변수인 k번만큼 반복한다.

모든 반복이 끝나면 result를 Array로 캐스팅해서 리턴하면 해결된다.

반응형