Notice
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 |
Tags
- 플러터 설치 2022
- 서비스 vs 쓰레드
- 안드로이드 레트로핏 crud
- android ar 개발
- 안드로이드 라이선스
- 서비스 쓰레드 차이
- 클래스
- rxjava hot observable
- 안드로이드 레트로핏 사용법
- rxjava cold observable
- 자바 다형성
- Rxjava Observable
- 2022 플러터 설치
- jvm 작동 원리
- 객체
- 스택 자바 코드
- 안드로이드 유닛테스트란
- 안드로이드 유닛 테스트 예시
- 멤버변수
- 안드로이드 라이선스 종류
- 스택 큐 차이
- rxjava disposable
- ANR이란
- 안드로이드 유닛 테스트
- 큐 자바 코드
- 안드로이드 os 구조
- jvm이란
- ar vr 차이
- 2022 플러터 안드로이드 스튜디오
- android retrofit login
Archives
- Today
- Total
나만을 위한 블로그
[Algorithm] 프로그래머스 - 5명씩 (Kotlin) 본문
728x90
반응형
최대 5명씩 탑승 가능한 놀이기구를 타기 위해 줄을 서 있는 사람들의 이름이 담긴 문자열 리스트 names가 주어질 때, 앞에서부터 5명씩 묶은 그룹의 가장 앞에 서 있는 사람들의 이름을 담은 리스트를 리턴하는 함수를 완성하라. 마지막 그룹이 5명이 되지 않더라도 가장 앞 사람의 이름을 포함한다
주먹구구식으로 푼다면 아래와 같다.
class Solution {
fun solution(names: Array<String>): ArrayList<String> {
val result = names.toMutableList().chunked(5)
val resultArr = arrayListOf<String>()
repeat(result.size) {
resultArr.add(result[it][0])
}
return resultArr
}
}
코틀린의 chunked()를 사용하면 간단하게 풀 수 있다. 핵심은 사람 이름을 5개씩 묶은 리스트를 리턴하고 5명이 되지 않더라도 가장 앞 사람의 이름을 포함하는 리스트를 만드는 것인데, chunked()가 이 역할을 하는 함수다.
https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.collections/chunked.html
이 컬렉션을 주어진 크기를 초과하지 않는 리스트의 리스트(List<List<T>>)로 분할한다. 결과 목록의 마지막 목록에는 지정된 크기보다 적은 수의 요소가 있을 수 있다
좀 더 간결하게 만들면 아래와 같다.
class Solution {
fun solution(names: Array<String>): Array<String> {
return names.toList().chunked(5) { it[0] }.toTypedArray()
}
}
반응형
'알고리즘 문제 풀이 > 프로그래머스' 카테고리의 다른 글
[Algorithm] 프로그래머스 - n보다 커질 때까지 더하기 (Kotlin) (0) | 2024.05.16 |
---|---|
[Algorithm] 프로그래머스 - 할 일 목록 (Kotlin) (0) | 2024.05.16 |
[Algorithm] 프로그래머스 - 홀수 vs 짝수 (Kotlin) (0) | 2024.05.16 |
[Algorithm] 프로그래머스 - n개 간격의 원소들 (Kotlin) (0) | 2024.04.20 |
[Algorithm] 프로그래머스 - n번째 원소까지 (Kotlin) (0) | 2024.04.20 |
Comments