Namespaces
Variants

std:: stable_sort

From cppreference.net
Algorithm library
Constrained algorithms and algorithms on ranges (C++20)
Constrained algorithms, e.g. ranges::copy , ranges::sort , ...
Execution policies (C++17)
Non-modifying sequence operations
Batch operations
(C++17)
Search operations
Modifying sequence operations
Copy operations
(C++11)
(C++11)
Swap operations
Transformation operations
Generation operations
Removing operations
Order-changing operations
(until C++17) (C++11)
(C++20) (C++20)
Sampling operations
(C++17)

Sorting and related operations
Partitioning operations
Sorting operations
Binary search operations
(on partitioned ranges)
Set operations (on sorted ranges)
Merge operations (on sorted ranges)
Heap operations
Minimum/maximum operations
Lexicographical comparison operations
Permutation operations
C library
Numeric operations
Operations on uninitialized memory
Definido en el encabezado <algorithm>
template < class RandomIt >
void stable_sort ( RandomIt first, RandomIt last ) ;
(1) (constexpr desde C++26)
template < class ExecutionPolicy, class RandomIt >

void stable_sort ( ExecutionPolicy && policy,

RandomIt first, RandomIt last ) ;
(2) (desde C++17)
template < class RandomIt, class Compare >
void stable_sort ( RandomIt first, RandomIt last, Compare comp ) ;
(3) (constexpr desde C++26)
template < class ExecutionPolicy, class RandomIt, class Compare >

void stable_sort ( ExecutionPolicy && policy,

RandomIt first, RandomIt last, Compare comp ) ;
(4) (desde C++17)

Ordena los elementos en el rango [ first , last ) en orden no decreciente. Se garantiza que se preservará el orden de los elementos equivalentes.

1) Los elementos están ordenados con respecto a operator < (until C++20) std:: less { } (since C++20) .
3) Los elementos están ordenados con respecto a comp .
2,4) Igual que (1,3) , pero ejecutado de acuerdo con la policy .
Estas sobrecargas participan en la resolución de sobrecarga solo si se cumplen todas las siguientes condiciones:

std:: is_execution_policy_v < std:: decay_t < ExecutionPolicy >> es true .

(hasta C++20)

std:: is_execution_policy_v < std:: remove_cvref_t < ExecutionPolicy >> es true .

(desde C++20)

Si se satisface cualquiera de las siguientes condiciones, el comportamiento es indefinido:

(hasta C++11)
(desde C++11)

Contenidos

Parámetros

first, last - el par de iteradores que define el rango de elementos a ordenar
policy - la política de ejecución a utilizar
comp - objeto función de comparación (es decir, un objeto que satisface los requisitos de Compare ) que devuelve ​ true si el primer argumento es menor que (es decir, está ordenado antes que) el segundo.

La firma de la función de comparación debe ser equivalente a la siguiente:

bool cmp ( const Type1 & a, const Type2 & b ) ;

Aunque la firma no necesita tener const & , la función no debe modificar los objetos pasados a ella y debe poder aceptar todos los valores de tipo (posiblemente const) Type1 y Type2 independientemente de la categoría de valor (por lo tanto, Type1& no está permitido , ni tampoco Type1 a menos que para Type1 un movimiento sea equivalente a una copia (desde C++11) ).
Los tipos Type1 y Type2 deben ser tales que un objeto de tipo RandomIt pueda ser desreferenciado y luego convertido implícitamente a ambos. ​

Requisitos de tipo
-
RandomIt debe cumplir con los requisitos de LegacyRandomAccessIterator .
-
Compare debe cumplir con los requisitos de Compare .

Complejidad

Dado N como last - first :

1,2) O(N·log(N)) comparaciones usando operator < (hasta C++20) std:: less { } (desde C++20) si hay suficiente memoria adicional disponible, de lo contrario O(N·log 2
(N))
comparaciones.
3,4) O(N·log(N)) aplicaciones del comparador comp si hay suficiente memoria adicional disponible, de lo contrario O(N·log 2
(N))
aplicaciones.

Excepciones

Las sobrecargas con un parámetro de plantilla llamado ExecutionPolicy reportan errores de la siguiente manera:

  • Si la ejecución de una función invocada como parte del algoritmo lanza una excepción y ExecutionPolicy es uno de los standard policies , std::terminate es llamado. Para cualquier otro ExecutionPolicy , el comportamiento está definido por la implementación.
  • Si el algoritmo falla al asignar memoria, std::bad_alloc es lanzado.

Implementación posible

Consulte también las implementaciones en libstdc++ y libc++ .

Notas

Esta función intenta asignar un búfer temporal de igual tamaño que la secuencia a ordenar. Si la asignación falla, se elige el algoritmo menos eficiente.

Macro de prueba de características Valor Std Característica
__cpp_lib_constexpr_algorithms 202306L (C++26) constexpr ordenación estable, sobrecargas ( 1 ) , ( 3 )

Ejemplo

#include <algorithm>
#include <array>
#include <iostream>
#include <string>
#include <vector>
struct Employee
{
    int age;
    std::string name; // No participa en las comparaciones
};
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';
}

Salida:

32, Arthur
108, Zaphod
108, Ford

Véase también

ordena un rango en orden ascendente
(function template)
ordena los primeros N elementos de un rango
(function template)
divide elementos en dos grupos preservando su orden relativo
(function template)
ordena un rango de elementos preservando el orden entre elementos iguales
(algorithm function object)