>백엔드 개발 >Golang >Go에서 맵을 사용하여 한 정수 조각이 다른 정수 조각의 하위 집합인지 어떻게 효율적으로 확인할 수 있나요?

Go에서 맵을 사용하여 한 정수 조각이 다른 정수 조각의 하위 집합인지 어떻게 효율적으로 확인할 수 있나요?

Barbara Streisand
Barbara Streisand원래의
2024-10-27 08:11:31976검색

How can I efficiently determine if one slice of integers is a subset of another in Go using a map?

Map을 사용하여 Go에서 정수 슬라이스의 하위 집합 검사

한 정수 조각이 다른 정수 조각의 하위 집합인지 확인하려면 단순한 것 이상의 효율적인 솔루션이 필요합니다. 반복. 이 기사에서는 맵을 활용하여 검사를 최적화하는 솔루션을 소개합니다.

하위 집합 정의

슬라이스의 모든 요소가 포함된 슬라이스는 다른 슬라이스의 하위 집합으로 간주됩니다. 후자는 중복이 포함될 수 있습니다. 예를 들어, {1, 2, 3}은 {1, 2, 3, 4}의 하위 집합이지만 {1, 2, 2}는 {1, 2, 3, 4}의 하위 집합이 아닙니다.

맵 기반 구현

제공되는 솔루션은 맵을 사용하여 슬라이스가 하위 집합인지 효율적으로 결정합니다. 각 요소의 개수를 값으로 사용하여 두 번째 조각에서 맵을 구성합니다. 그런 다음 첫 번째 조각을 반복하고 맵에 각 요소가 있는지 확인합니다. 충분한 중복이 있는 모든 요소가 발견되면 첫 번째 슬라이스는 하위 집합으로 간주됩니다.

샘플 코드

<code class="go">import "fmt"

// subset returns true if the first array is completely
// contained in the second array. There must be at least
// the same number of duplicate values in second as there
// are in first.
func subset(first, second []int) bool {
    set := make(map[int]int)
    for _, value := range second {
        set[value]++
    }

    for _, value := range first {
        if count, ok := set[value]; !ok {
            return false
        } else if count < 1 {
            return false
        } else {
            set[value] = count - 1
        }
    }

    return true
}

func main() {
    fmt.Println(subset([]int{1, 2, 3}, []int{1, 2, 3, 4}))
    fmt.Println(subset([]int{1, 2, 2}, []int{1, 2, 3, 4}))
}</code>

출력

true
false

결론

이 맵 기반 솔루션은 하나의 정수 슬라이스가 다른 정수 슬라이스의 하위 집합인지 여부를 효율적으로 확인하여 잠재적인 중복 값을 처리합니다. Go에서 이러한 일반적인 문제를 해결하기 위한 최적화된 접근 방식을 제공합니다.

위 내용은 Go에서 맵을 사용하여 한 정수 조각이 다른 정수 조각의 하위 집합인지 어떻게 효율적으로 확인할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.