std:: stable_sort
|
Определено в заголовке
<algorithm>
|
||
|
template
<
class
RandomIt
>
void stable_sort ( RandomIt first, RandomIt last ) ; |
(1) | (constexpr начиная с C++26) |
|
template
<
class
ExecutionPolicy,
class
RandomIt
>
void
stable_sort
(
ExecutionPolicy
&&
policy,
|
(2) | (начиная с C++17) |
|
template
<
class
RandomIt,
class
Compare
>
void stable_sort ( RandomIt first, RandomIt last, Compare comp ) ; |
(3) | (constexpr начиная с C++26) |
|
template
<
class
ExecutionPolicy,
class
RandomIt,
class
Compare
>
void
stable_sort
(
ExecutionPolicy
&&
policy,
|
(4) | (начиная с C++17) |
Сортирует элементы в диапазоне
[
first
,
last
)
в неубывающем порядке. Порядок эквивалентных элементов гарантированно сохраняется.
|
std:: is_execution_policy_v < std:: decay_t < ExecutionPolicy >> является true . |
(до C++20) |
|
std:: is_execution_policy_v < std:: remove_cvref_t < ExecutionPolicy >> является true . |
(начиная с C++20) |
Если выполняется любое из следующих условий, поведение является неопределённым:
|
(до C++11) |
|
(начиная с C++11) |
Содержание |
Параметры
| first, last | - | пара итераторов, определяющих диапазон элементов для сортировки |
| policy | - | используемая политика выполнения |
| comp | - |
функция сравнения (т.е. объект, удовлетворяющий требованиям
Compare
), которая возвращает
true
если первый аргумент
меньше
второго (т.е. упорядочен
перед
вторым).
Сигнатура функции сравнения должна быть эквивалентна следующей: bool cmp ( const Type1 & a, const Type2 & b ) ;
Хотя сигнатура не обязана содержать
const
&
, функция не должна модифицировать передаваемые объекты и должна быть способна принимать все значения типов (возможно const)
|
| Требования к типам | ||
-
RandomIt
должен удовлетворять требованиям
LegacyRandomAccessIterator
.
|
||
-
Compare
должен удовлетворять требованиям
Compare
.
|
||
Сложность
Дано N как last - first :
(N)) сравнений.
(N)) применений.
Исключения
Перегрузки с параметром шаблона с именем
ExecutionPolicy
сообщают об ошибках следующим образом:
-
Если выполнение функции, вызванной как часть алгоритма, выбрасывает исключение и
ExecutionPolicyявляется одним из стандартных политик , std::terminate вызывается. Для любой другойExecutionPolicyповедение определяется реализацией. - Если алгоритму не удается выделить память, std::bad_alloc выбрасывается.
Возможная реализация
Смотрите также реализации в libstdc++ и libc++ .
Примечания
Эта функция пытается выделить временный буфер, равный по размеру сортируемой последовательности. Если выделение памяти завершается неудачей, выбирается менее эффективный алгоритм.
| Макрос тестирования возможностей | Значение | Стандарт | Функция |
|---|---|---|---|
__cpp_lib_constexpr_algorithms
|
202306L
|
(C++26) | constexpr стабильная сортировка, перегрузки ( 1 ) , ( 3 ) |
Пример
#include <algorithm> #include <array> #include <iostream> #include <string> #include <vector> struct Employee { int age; std::string name; // Не участвует в сравнениях }; bool operator<(const Employee& lhs, const Employee& rhs) { return lhs.age < rhs.age; } #if __cpp_lib_constexpr_algorithms >= 202306L consteval auto get_sorted() { auto v = std::array{3, 1, 4, 1, 5, 9}; std::stable_sort(v.begin(), v.end()); return v; } static_assert(std::ranges::is_sorted(get_sorted())); #endif int main() { std::vector<Employee> v{{108, "Zaphod"}, {32, "Arthur"}, {108, "Ford"}}; std::stable_sort(v.begin(), v.end()); for (const Employee& e : v) std::cout << e.age << ", " << e.name << '\n'; }
Вывод:
32, Arthur 108, Zaphod 108, Ford
Смотрите также
|
сортирует диапазон в порядке возрастания
(function template) |
|
|
сортирует первые N элементов диапазона
(function template) |
|
|
разделяет элементы на две группы, сохраняя их относительный порядок
(function template) |
|
|
(C++20)
|
сортирует диапазон элементов, сохраняя порядок между равными элементами
(algorithm function object) |