> 백엔드 개발 > C++ > 본문

내 Erase-Remove_If 코드가 중복되는 이유는 무엇입니까?

Barbara Streisand
풀어 주다: 2024-11-10 14:33:02
원래의
999명이 탐색했습니다.

Why Is My Erase-Remove_If Code Leaving Duplicates?

Erase-Remove_If 관용구: 올바른 적용

erase-remove_if 관용구는 컨테이너에서 요소를 효율적으로 제거하기 위한 다용도 기술입니다. 술부. 그러나 잘못 구현하면 예상치 못한 결과가 발생할 수 있습니다.

주어진 예에서는 eraser-remove_if를 사용하여 쌍의 벡터에서 .first 값이 4인 쌍을 제거하려고 했습니다. 그러나 코드에서 오류를 나타내는 중복 항목이 남았습니다.

올바른 코드는 다음과 같습니다.

stopPoints.erase(std::remove_if(stopPoints.begin(),
                                stopPoints.end(),
                                [](const stopPointPair stopPoint)-> bool 
                                       { return stopPoint.first == 4; }), 
                 stopPoints.end());
로그인 후 복사

설명은 erasure-remove_if 메커니즘에 있습니다.

작동 방식

std::remove_if는 벡터 내의 요소를 교체하여 처음부터 술어와 일치하지 않는 요소를 그룹화합니다. 그런 다음 제거할 첫 번째 요소에 반복자를 반환하여 유지하고 제거할 요소 사이의 구분을 표시합니다.

std::Vector::erase는 반환된 반복자에서 시작하여 모든 후속 요소를 지워 효과적으로 제거합니다. 조건자와 일치하는 모든 요소.

초기 코드에서는 std::erase의 두 번째 매개변수를 생략하여 반환된 반복자가 나타내는 요소만 제거했습니다. 술어와 일치하는 후속 요소가 지워지지 않았기 때문에 중복이 발생했습니다.

두 번째 매개변수인 stopPoints.end()를 포함하여 반환된 반복자에서 시작하여 끝까지의 범위를 제거하도록 지우기에 지시합니다. 벡터를 사용하여 일치하는 모든 요소가 제거되도록 합니다.

지우기-제거 관용어에 대한 더 포괄적인 정보는 Wikipedia 항목을 참조하세요: https://en.wikipedia.org/wiki/Erase–remove_idiom

위 내용은 내 Erase-Remove_If 코드가 중복되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿