c++ sort比较函数的使用

先给结论:简单的来讲,sort的每次都会选择两个数信息比较,而选择函数会通过返回true或者false来控制排序,true是升序,false是降序。

在C++中,std::sort函数用于对容器中的元素进行排序。std::sort函数通常接受三个参数:要排序的容器的起始迭代器、结束迭代器以及用于比较元素的比较函数。

比较函数可以是普通函数,也可以是lambda函数。比较函数的作用是用于指定元素的相对顺序,即确定元素在排序结果中的位置。

下面是一个示例,展示了如何使用std::sort函数和比较函数对容器中的元素进行排序:

cpp 复制代码
#include <iostream>
#include <algorithm>
#include <vector>

bool compare(int a, int b) {
    return a < b;
}

int main() {
    std::vector<int> vec = {5, 2, 8, 1, 6};

    // 使用普通函数作为比较函数
    std::sort(vec.begin(), vec.end(), compare);

    // 输出排序后的结果
    for (int num : vec) {
        std::cout << num << " ";
    }
    std::cout << std::endl;

    return 0;
}

上面的示例中,compare函数用于指定元素的比较逻辑,根据a < b的结果来确定a和b的相对顺序。在std::sort函数调用时,传入compare函数作为比较函数,实现升序排序。

除了使用普通函数,还可以使用lambda函数来作为比较函数,如下所示:

cpp 复制代码
#include <iostream>
#include <algorithm>
#include <vector>

int main() {
    std::vector<int> vec = {5, 2, 8, 1, 6};

    // 使用lambda函数作为比较函数,实现降序排序
    std::sort(vec.begin(), vec.end(), [](int a, int b) {
        return a > b;
    });

    // 输出排序后的结果
    for (int num : vec) {
        std::cout << num << " ";
    }
    std::cout << std::endl;

    return 0;
}

上述代码中,lambda函数[](int a, int b) { return a > b; }用于实现降序排序,其中a > b表示降序排序的逻辑。在std::sort函数调用时,传入lambda函数作为比较函数,实现对容器中元素的降序排序。

总之,比较函数在std::sort函数中起着关键作用,通过比较函数可以灵活地指定元素的相对顺序,从而实现不同的排序效果。

相关推荐
小何好运暴富开心幸福17 小时前
C++之再谈类与对象
开发语言·c++·vscode
郝学胜-神的一滴18 小时前
中秋特别篇:使用QtOpenGL和着色器绘制星空与满月
开发语言·c++·算法·软件工程·着色器·中秋
JuneXcy19 小时前
C++知识点总结用于打算法
c++·算法·图论
ajassi200019 小时前
开源 C++ QT QML 开发(六)自定义控件--波形图
c++·qt·开源
_OP_CHEN19 小时前
C++基础:(八)STL简介
开发语言·c++·面试·stl
it技术20 小时前
C++ 设计模式原理与实战大全-架构师必学课程 | 完结
c++
zhuzhuxia⌓‿⌓20 小时前
线性表的顺序和链式存储
数据结构·c++·算法
小苏兮20 小时前
【C++】stack与queue的使用与模拟实现
开发语言·c++
杨小码不BUG21 小时前
小鱼的数字游戏:C++实现与算法分析(洛谷P1427)
c++·算法·数组·信奥赛·csp-j/s
高山有多高21 小时前
栈:“后进先出” 的艺术,撑起程序世界的底层骨架
c语言·开发语言·数据结构·c++·算法