remove_if std::map과 동일
C에서 std::remove_if 알고리즘은 다음을 충족하는 시퀀스에서 요소를 효과적으로 제거할 수 있습니다. 특정 조건. 그러나 이 알고리즘은 std::map과 같은 연관 컨테이너에 직접 적용할 수 없습니다.
맵 작업을 할 때는 수정된 접근 방식이 필요합니다. 일치하는 모든 요소를 맹목적으로 지우고 반복자를 무효화하는 대신 맵을 반복하고 조건에 따라 각 요소를 확인하는 것이 더 안전한 방법입니다.
다음 코드 조각을 고려하세요.
std::map<int, std::string> aMap; aMap[2] = "two"; aMap[3] = "three"; aMap[4] = "four"; aMap[5] = "five"; aMap[6] = "six"; std::map<int, std::string>::iterator iter = aMap.begin(); std::map<int, std::string>::iterator endIter = aMap.end(); for (; iter != endIter;) { if (Some Condition) { // Safe to erase, invalidates only the current iterator iter = aMap.erase(iter); } else { ++iter; } }
In 이 접근 방식에서는 요소가 조건을 충족하지 않는 경우에만 반복자를 증가시킵니다. 요소를 지우면 해당 요소를 가리키는 반복자가 무효화되지만 맵의 다른 반복자에는 영향을 주지 않습니다. 따라서 요소를 지운 후에도 반복을 계속하는 것이 안전합니다.
이 수정된 알고리즘을 사용하면 컨테이너의 무결성을 유지하면서 사용자 정의 조건에 따라 std::map에서 요소를 안전하게 제거할 수 있습니다. .
위 내용은 C에서 `std::map`에 대해 `std::remove_if`와 동등한 것을 달성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!