#include <algorithm>
#include <vector>
template <class BidirectionalIterator, class UnaryPredicate>
BidirectionalIterator partition(BidirectionalIterator first,
BidirectionalIterator last, UnaryPredicate pred)
{
while (first != last) {
while (pred(*first)) {
++first;
if (first == last) return first;
}
do {
--last;
if (first == last) return first;
} while (!pred(*last));
std::swap(*first, *last);
++first;
}
return first;
}
int main() {
std::vector<int> v = { 1, 55, 17, 65, 40, 18, 77, 37, 77, 37 };
partition(v.begin(), v.end(), [](const int &i) {
return i < 40;
});
return 0;
}
Код не компилируется. Оба clang ++ (3.5.2/cygwin) и Visual Studio (2013) жалуются на неоднозначный вызов. Поскольку не используется директива using
, я не понимаю, что случилось. Чтобы успешно скомпилировать, используется префикс ::
.clang ++: error: call to 'partition' неоднозначно