#include <iostream> // std::cout
using namespace std;
#include <functional> // std::not1
#include <algorithm> // std::count_if
#include <vector>
int main () {
vector<int> sv = {3, 5, 10,12 };
vector<int> v = { 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15 };
auto validSelection = [&](auto& e) {
auto isSelected = [&] (auto& sve) {
return e == sve;
};
return find_if(sv.begin(), sv.end(), isSelected) != sv.end();
};
stable_partition(v.begin(), next(v.begin(),8) , not1(function<bool(int&)>(validSelection)));
for (int n : v) {
std::cout << n << ' ';
}
std::cout << '\n';
return 0;
}
I2luY2x1ZGUgPGlvc3RyZWFtPiAgICAgLy8gc3RkOjpjb3V0CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CiNpbmNsdWRlIDxmdW5jdGlvbmFsPiAgIC8vIHN0ZDo6bm90MQojaW5jbHVkZSA8YWxnb3JpdGhtPiAgICAvLyBzdGQ6OmNvdW50X2lmCiNpbmNsdWRlIDx2ZWN0b3I+CgppbnQgbWFpbiAoKSB7CiAgICB2ZWN0b3I8aW50PiBzdiA9IHszLCA1LCAxMCwxMiB9OwogICAgdmVjdG9yPGludD4gdiA9IHsgMSwyLDMsNCw1LDYsNyw4LDksMTAsMTEsMTIsMTMsMTQsMTUgfTsKICAgIGF1dG8gdmFsaWRTZWxlY3Rpb24gPSBbJl0oYXV0byYgZSkgewogICAgICAgIGF1dG8gaXNTZWxlY3RlZCA9IFsmXSAoYXV0byYgc3ZlKSB7CiAgICAgICAgICAgIHJldHVybiBlID09IHN2ZTsKICAgICAgICB9OwogICAgICAgIHJldHVybiBmaW5kX2lmKHN2LmJlZ2luKCksIHN2LmVuZCgpLCBpc1NlbGVjdGVkKSAhPSBzdi5lbmQoKTsKICAgIH07CiAgICBzdGFibGVfcGFydGl0aW9uKHYuYmVnaW4oKSwgbmV4dCh2LmJlZ2luKCksOCkgLCBub3QxKGZ1bmN0aW9uPGJvb2woaW50Jik+KHZhbGlkU2VsZWN0aW9uKSkpOwogICAgZm9yIChpbnQgbiA6IHYpIHsKICAgICAgICBzdGQ6OmNvdXQgPDwgbiA8PCAnICc7CiAgICB9CiAgICBzdGQ6OmNvdXQgPDwgJ1xuJzsKICAgIHJldHVybiAwOwp9Cg==