"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Go의 슬라이스에서 중복 항목을 효율적으로 제거하는 방법은 무엇입니까?

Go의 슬라이스에서 중복 항목을 효율적으로 제거하는 방법은 무엇입니까?

2024년 12월 22일에 게시됨
검색:790

How to Efficiently Remove Duplicate Items from a Slice in Go?

슬라이스에서 중복 항목 삭제

현재 상황에서는 슬라이스에서 중복 항목을 삭제할 때 문제가 발생합니다. 슬라이스를 반복하고 반복하는 동안 요소를 제거합니다. 중복 항목이 조각 끝에 있으면 색인 오류와 패닉이 발생할 수 있습니다.

이 문제를 해결하려면 고유한 요소를 조각 시작 부분에 복사한 다음 잘라내는 것이 더 효율적인 접근 방식입니다. 이후에는 초과 요소가 없습니다. 이를 수행하는 방법은 다음과 같습니다.

i := 0
for _, v := range cfg.Bootstrap {
    if v.PeerID == peer.PeerID && v.Address == peer.Address {
        continue
    }
    cfg.Bootstrap[i] = v
    i  
}
cfg.Bootstrap = cfg.Bootstrap[:i]

이 코드에서는:

  • 변수 i를 0으로 초기화합니다. 이는 새로 잘라낸 슬라이스의 인덱스 위치를 나타냅니다.
  • cfg.Bootstrap의 각 요소를 반복합니다.
  • 요소가 두 요소와 모두 일치하는 경우 사용자가 제공한 PeerID 및 주소는 건너뜁니다.
  • 그렇지 않으면 요소를 새 슬라이스의 i번째 위치에 복사합니다.
  • i를 다음 위치로 증가시킵니다.
  • 루프 후에 새 슬라이스를 cfg.Bootstrap에 할당하고 이를 올바른 위치로 자릅니다. length.

이 접근 방식을 사용하면 모든 중복 요소가 제거되고 프로세스 전반에 걸쳐 슬라이스가 일관되게 유지됩니다. 반복하는 동안 요소를 제거할 때 발생할 수 있는 인덱스 오류 및 패닉을 방지합니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3