>백엔드 개발 >C++ >반복자를 무효화하지 않고 반복하는 동안 벡터에서 요소를 제거하는 방법은 무엇입니까?

반복자를 무효화하지 않고 반복하는 동안 벡터에서 요소를 제거하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-10-31 01:23:29380검색

How to Remove Elements from a Vector while Iterating Without Invalidating Iterators?

반복하는 동안 벡터에서 요소 제거

std::Vector를 반복하고 특정 기준에 따라 요소를 삭제할 때 다음을 사용합니다. 여러 벡터 또는 무효화된 반복자가 발생할 수 있습니다. 이 문제는 보다 적합한 데이터 구조를 활용하거나 대체 접근 방식을 사용하여 해결할 수 있습니다.

대체 데이터 구조

여러 벡터를 사용하는 대신 다음과 같은 대체 데이터 구조를 활용하는 것이 좋습니다. as:

  • std::set: 자동으로 정렬되는 고유 요소 컬렉션을 유지 관리합니다. 이 속성은 중복을 피하면서 특정 순서로 요소에 액세스하는 데 유용할 수 있습니다.
  • std::list: 이중 연결 목록을 사용하면 효율적인 삽입 및 삭제 작업이 가능합니다. 반복자는 요소 제거 후에도 유효하므로 요소 순서가 자주 변경되는 시나리오에 적합합니다.

수정된 접근 방식

다른 데이터 구조를 사용하는 경우 실현 가능하지 않음, std::벡터 내에 해결 방법이 있습니다:

  1. 반복자 기반 접근 방식 사용: 루프를 사용하여 벡터를 반복하고 반복자에서 erase()를 호출합니다. 제거할 요소를 가리킵니다. 제거할 요소 수가 상대적으로 적은 경우 이 접근 방식이 효율적일 수 있습니다.
  2. 벡터 기반 접근 방식 사용: 벡터를 두 번 반복합니다. 첫 번째 반복에서는 제거할 요소를 식별하고 해당 인덱스를 별도의 벡터에 저장합니다. 두 번째 반복에서는 인덱스를 사용하여 요소를 지웁니다. 이 접근 방식은 많은 수의 요소를 제거해야 하는 경우 효율적일 수 있습니다.

이러한 대체 방법을 구현하면 반복자를 무효화하지 않고 효율적으로 반복하면서 std::Vector에서 요소를 제거할 수 있습니다.

위 내용은 반복자를 무효화하지 않고 반복하는 동안 벡터에서 요소를 제거하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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