C++(15): STL算法:排序(sort)

1. 简述

std::sort 是 C++ 标准库 <algorithm> 中提供的一个函数,用于对容器(如数组、向量等)中的元素进行排序。它基于比较操作对元素进行排序,通常使用高效的排序算法,如快速排序、归并排序或堆排序等。

在实际应用中,std::sort 通常会根据输入数据的大小和特性自适应地选择一种合适的排序算法。例如,对于小型数据集,它可能会选择插入排序或选择排序等简单算法,因为这些算法在小规模数据上通常具有较低的常数因子。对于大型数据集,它可能会选择快速排序、归并排序或堆排序等更高效的算法。

2. 原型

template<class RandomIt>

void sort( RandomIt first, RandomIt last );

template<class RandomIt, class Compare>

void sort( RandomIt first, RandomIt last, Compare comp );

****first 和 last:****这两个参数是迭代器,分别指向要排序序列的开始和结束。注意,last 指向的是序列"之后"的位置,所以序列中的元素范围实际上是 [first, last)。

****comp:****这是一个可选的比较函数或函数对象,用于定义排序的顺序。如果提供了这个参数,std::sort 会使用这个比较函数来确定元素的顺序。默认情况下,std::sort 使用 < 操作符来比较元素。

3. 稳定排序

有时候使用sort时,值相同的两个元素,在排序前后的顺序不一定相同,如何解决这个问题呢?答案是使用std::stable_sort

std::stable_sort 是 C++ 标准库 <algorithm> 头文件中提供的一个函数,用于对容器(如数组、向量等)中的元素进行稳定排序。与 std::sort 不同,std::stable_sort 保证了具有相同值的元素的相对顺序在排序后保持不变。

std::stable_sort的使用与std::sort一样,此处不过多赘述。

4. 排序例程

(1)排序数组(正向)

复制代码
int array[] = {3, 1, 5, 9, 5, 7, 9, 3, 5};

std::sort(array, array + sizeof(array) / sizeof(array[0]));

(2)排序数组(反向)

复制代码
int arr[] = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5};

int n = sizeof(arr) / sizeof(arr[0]);

sort(arr, arr + n, greater<int>());

(3)vector排序

复制代码
std::vector<int> v = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5};

std::sort(v.begin(), v.end());

(4)自定义数据排序

对自定义数据进行排序时,需要实现排序函数对象。

复制代码
#include <iostream>

#include <fstream>

#include <sstream>

#include <iomanip>

#include <algorithm>


typedef struct _Student

{

    std::string name;  

    int age;  

}Student;

 

bool compareByAge(const Student& a, const Student& b)

{

    return a.age < b.age;  

}  

 

int main(int argc, char* argv[])

{

    std::vector<Student> people;

    /** 加入一些学生信息. */  

    std::sort(people.begin(), people.end(), compareByAge);  

}
相关推荐
Hello:CodeWorld6 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
搬砖魁首8 小时前
基础能力系列 - 多线程2 - 条件变量
c++·rust·条件变量·原子类型·线程同步互斥
chase_my_dream8 小时前
C++ + SLAM 高频面试问题整理
开发语言·c++·面试
牛油果子哥q9 小时前
【C++ STL string 】C++ STL string 终极精讲:底层原理、内存机制、全套API、深浅拷贝、易错坑点与工程实战规范
数据库·c++
凡人叶枫10 小时前
Effective C++ 条款04:确定对象被使用前已先被初始化
java·linux·开发语言·c++·嵌入式开发
不想写代码的星星11 小时前
std::move 根本不移动,就像老婆饼里没有老婆
c++
redaijufeng11 小时前
C++雾中风景7:闭包
c++·算法·风景
小欣加油11 小时前
leetcode287寻找重复数
数据结构·c++·算法·leetcode
思麟呀11 小时前
C++11 核心特性(三):强类型枚举、static_assert 与 std::tuple
开发语言·c++
一拳一个呆瓜12 小时前
【STL】C++程序的启动与终止
c++·stl