문제
풀이
먼저 코틀린의 HashSet을 이용하여 중복된 단어의 입력을 방지한다. 이 set을 정렬하기 위해 MutableList로 형변환 시켜준다. 이 리스트를 Comparator를 이용하여 정렬시켜주기 위해 sortWith() 함수를 사용한다. 두 단어의 길이가 같은 경우에는 알파벳 순서에 따라 정렬하고, 아닌 경우에는 길이에 따라 정렬해준다. 이 후, 정렬된 리스트를 출력하면 된다.
코드
fun main() {
val br = System.`in`.bufferedReader()
val bw = System.out.bufferedWriter()
val num = br.readLine().toInt()
val word = hashSetOf<String>()
repeat(num) {
word.add(br.readLine())
}
word.toMutableList().apply {
sortWith { d1, d2 ->
if (d1.length == d2.length) {
d1.compareTo(d2)
} else {
d1.length - d2.length
}
}
this.forEach { // this는 mutableList()이다.
bw.append(it).append('\n')
}
}
bw.write("")
bw.flush()
bw.close()
br.close()
}
'알고리즘 > Baekjoon' 카테고리의 다른 글
[백준] 1920번: 수 찾기 - Kotlin[코틀린] (0) | 2023.07.20 |
---|---|
[백준] 11726번: 2×n 타일링 - Kotlin[코틀린] (0) | 2023.07.20 |
[백준] 1003번: 피보나치 함수 - Kotlin[코틀린] (0) | 2023.07.19 |
[백준] 1929번: 소수 구하기 - Kotlin[코틀린] (0) | 2023.07.18 |
[백준] 2751번: 수 정렬하기 2 - Kotlin[코틀린] (0) | 2023.07.17 |