Kotlin/Basic

집합: Set, MutableSet

몰름보반장 2023. 12. 3. 21:52


Atomic Kotlin Atom26: 집합을 정리한 내용에 개인 스터디한 것을 추가

Set

Set은 각각의 값이 오직 하나만 존재 가능한 컬렉션

보통 in이나 contains()를 사용해서 원소 포함여부를 검사할 때 사용

fun main() {
    // 중복 허용 안함
    val intSet = setOf(1, 1, 2, 3, 9, 9, 4)

    // 원소 순서는 중요x
    println(setOf(1, 2) == setOf(2, 1)) // >> true

    // 원소 포함 여부 검사(in)
    println((9 in intSet) == true) // >> true
    println((99 in intSet) == false) // >> true

    // 원소 포함 여부 검사(contains)
    println(intSet.contains(9)) // >> true
    println(intSet.contains(99)) // >> false

    // 이 집합이 다른 집합을 포함하는가?
    println(intSet.containsAll(setOf(1, 9, 2))) // >> true

    // 합집합
    println(intSet.union(setOf(3, 4, 5, 6))) // >> [1, 2, 3, 4, 5, 6, 9]

    // 교집합
    println(intSet intersect setOf(0, 1, 2, 7, 8)) // >> [1, 2]

    // 차집합
    println(intSet subtract setOf(0, 1, 9, 10)) // >> [2, 3, 4]
    println(intSet - setOf(0, 1, 9, 10)) // >> [2, 3, 4]
}

Set은 원소 중복을 자동으로 없앤다.
원소 순서는 중요하지 않다.
부분 / 합 / 교 / 차 집합 등의 벤 다이어그램 연산 수행 가능

List의 중복을 제거하려면 Set으로 변환

val list = listOf(1, 1, 2, 3, 2, 4)
val    listToSet = list.toSet()
println(listToSet) // >> [1, 2, 3, 4]

setOf()는 읽기 전용 집합
가변 Set은 mutableSetOf()로 생성

MutableSet

아래는 mutableSetOf에서 사용 가능한 메서드들의 사용법을 정리한 예시 코드

un main() {
    // MutableSet 생성, 중복 허용 안함
    val mutableIntSet = mutableSetOf(1, 2, 3, 4, 5)

    // 요소 추가
    mutableIntSet.add(6) // set = [1, 2, 3, 4, 5, 6]
    println(mutableIntSet)

    // 여러 요소 추가
    mutableIntSet.addAll(listOf(7, 8)) // set = [1, 2, 3, 4, 5, 6, 7, 8]
    println(mutableIntSet)

    // 요소 제거
    mutableIntSet.remove(1) // set = [2, 3, 4, 5, 6, 7, 8]
    println(mutableIntSet)

    // 여러 요소 제거
    mutableIntSet.removeAll(listOf(2, 3)) // set = [4, 5, 6, 7, 8]
    println(mutableIntSet)

    // 특정 조건을 만족하는 요소 제거
    mutableIntSet.removeIf { it % 2 == 0 } // set = [5, 7]
    println(mutableIntSet)

    // 모든 요소 제거
    mutableIntSet.clear() // set = []
    println(mutableIntSet)

    // 요소 포함 여부 확인
    println(mutableIntSet.contains(5)) // >> false

    // 다른 셋의 모든 요소를 포함하는지 확인
    println(mutableIntSet.containsAll(setOf(5, 7))) // >> false
}

본인의 경우, 가장 위에 언급된 것 처럼 중복이 없는 데이터 리스트에서 특정 데이터가 존재하는지 파악하기 위해 애용하는 자료구조이다.

Set에서 데이터를 검사하는 것은 O(1)의 시간복잡도로 매우 빠르기 때문