찾다
백엔드 개발GolangGo의 슬라이스에서 중복 요소를 효율적으로 제거하려면 어떻게 해야 합니까?

How Can I Efficiently Remove Duplicate Elements from Slices in Go?

Go에서 슬라이스에서 중복 제거

Go에서 슬라이스로 작업할 때 중복된 요소를 필터링해야 하는 상황이 발생할 수 있습니다. 이 기사에서는 Go에서 이를 달성하기 위한 다양한 접근 방식을 살펴봅니다.

비효율적인 루프 기반 솔루션

일반적이지만 비효율적인 기술은 슬라이스를 반복하고 중첩 루프를 사용하여 중복을 확인하는 것입니다. 이 방법은 효과가 있지만 시간 복잡도가 O(n^2)이므로 큰 조각의 경우 속도가 느려질 수 있습니다.

효율적인 맵 기반 솔루션

보다 효율적인 접근 방식은 Go에서 구축한 -지도 유형. 다음은 두 가지 솔루션입니다.

일반 솔루션:

제네릭(Go 1.18에서 도입됨)을 사용하면 동급형.

func removeDuplicate[T comparable](sliceList []T) []T {
    allKeys := make(map[T]bool)
    list := []T{}
    for _, item := range sliceList {
        if _, value := allKeys[item]; !value {
            allKeys[item] = true
            list = append(list, item)
        }
    }
    return list
}

최적화된 솔루션 문자열:

문자열 조각의 경우 맵 키 조회를 최적화하는 전용 함수를 생성할 수 있습니다.

func removeDuplicateStr(strSlice []string) []string {
    allKeys := make(map[string]bool)
    list := []string{}
    for _, item := range strSlice {
        if _, value := allKeys[item]; !value {
            allKeys[item] = true
            list = append(list, item)
        }
    }
    return list
}

성능 비교

일반 솔루션은 다음을 증명합니다. 문자열 관련 솔루션보다 더 유연하지만 약간 느립니다. 큰 슬라이스에 대한 벤치마킹은 문자열별 솔루션이 훨씬 더 빠르다는 것을 보여줍니다.

결론

Go의 슬라이스에서 중복 항목을 제거할 때 가장 효율적인 접근 방식을 선택하는 것은 특정 사용 사례와 데이터 유형에 따라 다릅니다. . 복잡한 데이터 유형이나 작은 조각의 경우 일반 솔루션이 적합합니다. 대규모 문자열 조각의 경우 문자열별 솔루션이 최적의 성능을 제공합니다.

위 내용은 Go의 슬라이스에서 중복 요소를 효율적으로 제거하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

Go의 "Strings"패키지는 문자열 작동 효율적이고 간단하게 만드는 풍부한 기능을 제공합니다. 1) STRINGS.CONTAINS ()를 사용하여 하위 문자열을 확인하십시오. 2) strings.split ()를 사용하여 데이터를 구문 분석 할 수 있지만 성능 문제를 피하기 위해주의해서 사용해야합니다. 3) strings.join ()은 문자열 서식에 적합하지만 작은 데이터 세트의 경우 루핑 =가 더 효율적입니다. 4) 큰 문자열의 경우 문자열을 사용하여 문자열을 만드는 것이 더 효율적입니다.

GO : 표준 '문자열'패키지를 사용한 문자열 조작GO : 표준 '문자열'패키지를 사용한 문자열 조작May 09, 2025 am 12:07 AM

Go는 문자열 작업에 "Strings"패키지를 사용합니다. 1) splice strings에 strings.join 기능을 사용하십시오. 2) 문자열을 사용하여 기능을 포함하여 하위 문자열을 찾으십시오. 3) 문자열을 사용하십시오. 이러한 기능은 효율적이고 사용하기 쉽고 다양한 문자열 처리 작업에 적합합니다.

Go의 '바이트'패키지로 마스터 링 바이트 슬라이스 조작 : 실용 가이드Go의 '바이트'패키지로 마스터 링 바이트 슬라이스 조작 : 실용 가이드May 09, 2025 am 12:02 AM

the byteSpackageOsestementialforeficientsliceManipulation, ontowerfunctionslikecececectains, index, andreplaceforsearching 및 modifyingbinaryData.ItenHancesBinaryData, MakingIvitalToolforHandlingBinaryData, NetworkProtocols 및 filei

Go Binary Encoding/Decoding : '인코딩/바이너리'패키지로 작업하십시오Go Binary Encoding/Decoding : '인코딩/바이너리'패키지로 작업하십시오May 08, 2025 am 12:13 AM

Go는 이진 인코딩 및 디코딩을 위해 "인코딩/이진"패키지를 사용합니다. 1)이 패키지는 binary.wart.write 및 binary.Read 기능을 작성하고 읽기 데이터를 제공합니다. 2) 올바른 엔디언 (예 : Bigendian 또는 Littleendian)을 선택하는 데주의를 기울이십시오. 3) 데이터 정렬 및 오류 처리도 데이터의 정확성과 성능을 보장하는 핵심입니다.

GO : 표준 '바이트'패키지가있는 바이트 슬라이스 조작GO : 표준 '바이트'패키지가있는 바이트 슬라이스 조작May 08, 2025 am 12:09 AM

"바이트"PackageOffersefficientFunctionSformanipulatingByteslices.1) audeBytes.joinforconcateNatingSlices, 2) bytes.bufferforIncrementalWriting, 3) bytes.indexorBytes.IndexByTeForsearching, 4) bytes.ReaderReadingInCunks, 및 5) thepliteTor

GO 인코딩/이진 패키지 : 이진 작업의 성능 최적화GO 인코딩/이진 패키지 : 이진 작업의 성능 최적화May 08, 2025 am 12:06 AM

theencoding/binarypackageingofectiveficizatebinaryoperationsduetoitssupportforendiannessandefficientdatahandling.toenhanceperformance : 1) usebinary.nativeBinary.nativeBinary.nativeBinary.nativeEndianFornativeendiannesstoavoidByteswapping.2) BatchReadandWriteOperationStoredUtei/over

바이트 패키지 : 짧은 참조 및 팁바이트 패키지 : 짧은 참조 및 팁May 08, 2025 am 12:05 AM

GO의 바이트 패키지는 주로 바이트 슬라이스를 효율적으로 처리하는 데 사용됩니다. 1) Bytes를 사용하여 Buffer는 불필요한 메모리 할당을 피하기 위해 스트링 스 플라이 싱을 효율적으로 수행 할 수 있습니다. 2) BYTES.Equal 함수는 바이트 슬라이스를 빠르게 비교하는 데 사용됩니다. 3) bytes.index, bytes.split 및 bytes.replaceall 함수를 사용하여 바이트 슬라이스를 검색하고 조작 할 수 있지만 성능 문제에주의를 기울여야합니다.

바이트 패키지를 이동하십시오 : 바이트 슬라이스 조작을위한 실제 예바이트 패키지를 이동하십시오 : 바이트 슬라이스 조작을위한 실제 예May 08, 2025 am 12:01 AM

바이트 패키지는 바이트 슬라이스를 효율적으로 처리하기위한 다양한 기능을 제공합니다. 1) 바이트 시퀀스를 확인하려면 바이트를 사용하십시오. 2) 바이트 슬라이스를 분할하려면 BYTES.SPLIT를 사용하십시오. 3) 바이트 시퀀스 바이트를 교체하십시오. 4) Bytes.join을 사용하여 여러 바이트 슬라이스를 연결하십시오. 5) Bytes.Buffer를 사용하여 데이터를 작성하십시오. 6) 오류 처리 및 데이터 검증을 위해 결합 된 바이트.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.