이 튜토리얼에서는 C++에서 partition_point를 이해하는 프로그램에 대해 논의할 것입니다.
파티션 포인트는 주어진 범위의 첫 번째 값을 가리키는 반복자를 반환하는 메서드입니다. 범위는 술어가 참이 아닌 분할된 범위입니다.
예
#include <iostream> #include <algorithm> #include <vector> bool IsOdd(int i) { return (i % 2) == 1; } int main(){ std::vector<int> data{ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; std::vector<int> odd, even; std::stable_partition(data.begin(), data.end(), IsOdd); auto it = std::partition_point(data.begin(), data.end(), IsOdd); odd.assign(data.begin(), it); even.assign(it, data.end()); std::cout << "odd:"; for (int& x : odd) std::cout << ' ' << x; std::cout << '\n'; std::cout << "even:"; for (int& x : even) std::cout << ' ' << x; std::cout << '\n'; return 0; }
출력
odd: 1 3 5 7 9 even: 2 4 6 8 10